std::is_standard_layout (3) - Linux Manuals
std::is_standard_layout: std::is_standard_layout
NAME
std::is_standard_layout - std::is_standard_layout
Synopsis
Defined in header <type_traits>
template< class T >              (since C++11)
struct is_standard_layout;
If T is a standard layout type (that is, a scalar type, a standard-layout class, or an array of such type/class, possibly cv-qualified), provides the member constant value equal true. For any other type, value is false.
A standard-layout_class is a class that satisfies StandardLayoutType.
The behavior is undefined if std::remove_all_extents_t<T> is an incomplete type and not (possibly cv-qualified) void.
Template parameters
T - a type to check
Helper variable template
template< class T >                                                         (since C++17)
inline constexpr bool is_standard_layout_v = is_standard_layout<T>::value;
Inherited from std::integral_constant
Member constants
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
value    true if T is a standard-layout type , false otherwise
 
[static]
Member functions
 
operator bool (public member function)
operator()    returns value
 
(C++14)
Member types
Type       Definition
value_type bool
type       std::integral_constant<bool, value>
Notes
A pointer to a standard-layout class may be converted (with reinterpret_cast) to a pointer to its first non-static data member and vice versa.
If a standard-layout union holds two or more standard-layout structs, it is permitted to inspect the common initial part of them.
The macro offsetof can only be used with standard-layout classes.
Example
// Run this code
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 Output:
 
 
 See also
is_trivially_copyable        checks if a type is trivially copyable
 
(C++11)
is_pod                       checks if a type is a plain-old data (POD) type
 
(C++11)(deprecated in C++20)
 
offsetof                     (function macro)