Namespaces
Variants
Views
Actions

std::max_align_t

From cppreference.com
< cpp‎ | types
Revision as of 13:28, 7 May 2024 by Space Mission (Talk | contribs)

(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
 
 
Utilities library
General utilities
Relational operators (deprecated in C++20)
 
Type support
Basic types
Fixed width integer types (C++11)
Fixed width floating-point types (C++23)
max_align_t
(C++11)    
(C++17)
Numeric limits
C numeric limits interface
Runtime type information
 
Defined in header <cstddef>
typedef /*implementation-defined*/ max_align_t;
(since C++11)

std::max_align_t is a trivial standard-layout type whose alignment requirement is at least as strict (as large) as that of every scalar type.

Contents

[edit] Notes

Pointers returned by allocation functions such as std::malloc are suitably aligned for any object, which means they are aligned at least as strictly as std::max_align_t.

[edit] Example

#include <cstddef>
#include <iostream>
 
int main()
{
    std::cout << alignof(std::max_align_t) << '\n';
}

Possible output:

16

[edit] References

  • C++23 standard (ISO/IEC 14882:2024):
  • 17.2.4 Sizes, alignments, and offsets [support.types.layout] (p: 504-505)
  • C++20 standard (ISO/IEC 14882:2020):
  • 17.2.4 Sizes, alignments, and offsets [support.types.layout] (p: 507-508)
  • C++17 standard (ISO/IEC 14882:2017):
  • 21.2.4 Sizes, alignments, and offsets [support.types.layout] (p: 479)
  • C++14 standard (ISO/IEC 14882:2014):
  • 18.2 Types [support.types] (p: 443-444)
  • C++11 standard (ISO/IEC 14882:2011):
  • 18.2 Types [support.types] (p: 454-455)

[edit] See also

alignof operator(C++11) queries alignment requirements of a type[edit]
obtains the type's alignment requirements
(class template) [edit]
(C++11)
checks if a type is a scalar type
(class template) [edit]
C documentation for max_align_t