std::is_standard_layout
| Definido en el archivo de encabezado <type_traits>
|
||
template< class T > struct is_standard_layout; |
(desde C++11) | |
std::is_standard_layout es un UnaryTypeTrait.
Si T es un tipo con diseño estándar (es decir, un tipo escalar, una clase con diseño estándar, o un array de tal tipo o clase, posiblemente calificado-cv), proporciona la constante miembro value igual a true. Para cualquier otro tipo, value es false.
Una clase con diseño estándar es una clase que satisface a StandardLayoutType.
El comportamiento está indefinido si std::remove_all_extents_t<T> es un tipo incompleto y no (posiblemente calificado-cv) void.
El comportamiento de un programa que añade especializaciones para is_standard_layout o is_standard_layout_v (desde C++17) no está definido.
Parámetros de plantilla
| T | - | Un tipo a comprobar. |
Plantilla de variable auxiliar
<tbody> </tbody> template< class T > inline constexpr bool is_standard_layout_v = is_standard_layout<T>::value; |
(desde C++17) | |
Heredado de std::integral_constant
Constantes miembro
value [estático] |
true si T es un tipo con diseño estándar., de lo contrario false. (constante miembro pública estática) |
Funciones miembro
operator bool |
Convierte el objeto a bool, devuelve value. (función miembro pública) |
operator() (C++14) |
Devuelve value. (función miembro pública) |
Tipos miembro
| Tipo | Definición |
value_type
|
bool
|
type
|
std::integral_constant<bool, value>
|
Notas
Un puntero a una clase con diseño estándar puede convertirse (con reinterpret_cast) a un puntero a su primer dato miembro no estático y viceversa.
Si una unión con diseño estándar alberga dos o más estructuras con diseño estándar, se le permite inspeccionar la parte inicial común de ellas.
Se garantiza que la macro offsetof sea utilizable solamente con clases con diseño estándar.
Ejemplo
#include <iostream>
#include <type_traits>
struct A {
int m;
};
struct B {
int m1;
private:
int m2;
};
struct C {
virtual void foo();
};
int main()
{
std::cout << std::boolalpha;
std::cout << std::is_standard_layout<A>::value << '\n';
std::cout << std::is_standard_layout<B>::value << '\n';
std::cout << std::is_standard_layout<C>::value << '\n';
}
Salida:
true
false
false
Véase también
(C++11) |
Comprueba si un tipo es trivialmente copiable. (plantilla de clase) |
(C++11) |
Comprueba si un tipo es un tipo simple (POD). (plantilla de clase) |
| Desplazamiento de bytes desde el comienzo de un tipo de diseño estándar al miembro especificado. (macro de función) |