Namespaces
Variants
Views
Actions

std::aligned_union

From cppreference.com
< cpp‎ | types
Revision as of 22:08, 4 February 2014 by 98.164.7.43 (Talk)

(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
 
 
 
Type support
Basic types
Fundamental types
Fixed width integer types (C++11)
Numeric limits
C numeric limits interface
Runtime type information
Type traits
Primary type categories
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Type properties
(C++11)
(C++11)
(C++11)
(C++14)
Supported operations
Relationships and property queries
(C++11)
(C++11)
(C++11)
(C++11)
Type modifications
(C++11)(C++11)(C++11)
Type transformations
aligned_union
(C++11)
(C++11)
(C++11)
(C++11)
Type trait constants
 
Defined in header <type_traits>
template< std::size_t Len, class... Types >
struct aligned_union;
(since C++11)

Provides the member typedef type, which is a POD type of a size and alignment suitable for use as uninitialized storage for an object of any of the types listed in Types. The size of the storage is at least Len. std::aligned_union also determines the strictest (largest) alignment requirement among all Types and makes it available as the constant alignment_value.

Contents

[edit] Member types

Name Definition
type the POD type suitable for storage of any type from Types

[edit] Helper types

template< std::size_t Len, class... Types >
using aligned_union_t = typename aligned_union<Len,Types...>::type;
(since C++14)

[edit] Member constants

alignment_value
[static]
the strictest alignment requirement of all Types
(public static member constant)

[edit] Example

[edit] See also

obtains the type's alignment requirements
(class template) [edit]
defines the type suitable for use as uninitialized storage for types of given size
(class template) [edit]