std::is_standard_layout
| Definiert in der Kopfdatei <type_traits> |
||
| template< class T > struct is_standard_layout; |
(seit C++11) | |
std::is_standard_layout ist ein UnaryTypeTrait.
Wenn T ein Standard-Layout-Typ ist, stellt es die Member-Konstante value mit dem Wert true bereit. Für jeden anderen Typ ist value false.
Wenn std::remove_all_extents_t<T> ein unvollständiger Typ und nicht (möglicherweise cv-qualifiziertes) void ist, ist das Verhalten undefiniert.
Wenn das Programm Spezialisierungen für std::is_standard_layout oder std::is_standard_layout_v hinzufügt, ist das Verhalten undefiniert.
Inhalt |
[bearbeiten] Template-Parameter
| T | - | ein zu prüfender Typ |
[bearbeiten] Hilfsvariablen-Template
| template< class T > constexpr bool is_standard_layout_v = is_standard_layout<T>::value; |
(seit C++17) | |
Abgeleitet von std::integral_constant
Member-Konstanten
| value [static] |
true, wenn T ein Standard-Layout-Typ ist, andernfalls false(öffentliche statische Member-Konstante) |
Memberfunktionen
| operator bool |
konvertiert das Objekt zu bool, gibt value zurück (öffentliche Memberfunktion) |
| operator() (C++14) |
gibt value zurück (öffentliche Memberfunktion) |
Membertypen
| Typ | Definition |
value_type
|
bool |
type
|
std::integral_constant<bool, value> |
[edit] Anmerkungen
Ein Zeiger auf eine Standard-Layout-Klasse darf (mit reinterpret_cast) in einen Zeiger auf ihr erstes nicht-statisches Datenmitglied und umgekehrt konvertiert werden.
Wenn eine Standard-Layout-Union zwei oder mehr Standard-Layout-Strukturen enthält, ist es gestattet, deren gemeinsamen Anfangsteil zu inspizieren.
Das Makro offsetof ist nur garantiert mit Standard-Layout-Klassen verwendbar.
[edit] Beispiel
#include <type_traits> struct A { int m; }; static_assert(std::is_standard_layout_v<A> == true); class B: public A { int m; }; static_assert(std::is_standard_layout_v<B> == false); struct C { virtual void foo(); }; static_assert(std::is_standard_layout_v<C> == false); int main() {}
[edit] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 2015 | C++11 | T könnte ein Array eines unvollständigenKlassentyps mit unbekannter Größe sein |
Das Verhalten ist in diesem Fall nicht definiert. |
[edit] Siehe auch
| (C++11) |
prüft, ob ein Typ trivial kopierbar ist (Klassenvorlage) |
| (C++11)(veraltet in C++20) |
prüft, ob ein Typ ein Plain-Old-Data (POD)-Typ ist (Klassenvorlage) |
| Byte-Offset vom Anfang eines Standardlayout-Typs zu einem angegebenen Mitglied (function macro) |