命名空间
变体
操作

alignof 运算符 (C++11 起)

来自 cppreference.cn
< cpp‎ | 语言
 
 
C++ 语言
 
 

查询类型的对齐要求。

目录

[编辑] 语法

alignof( type-id )

返回 std::size_t 类型的值。

[编辑] 解释

返回 对齐方式,以字节为单位,它是由 type-id 指示的任何类型实例所需的。此类型可以是完整对象类型、元素类型完整的数组类型,或对这些类型之一的引用类型。

如果类型是引用类型,则此运算符返回引用类型的对齐方式;如果类型是数组类型,则返回元素类型的对齐要求。

[编辑] 注意

关于 alignof 返回值的含义和属性,请参阅对齐

[编辑] 关键词

alignof

[编辑] 示例

#include <iostream>
 
struct Foo
{
    int   i;
    float f;
    char  c;
};
 
// Note: alignas(alignof(long double)) below can be
// simplified to alignas(long double) if desired.
struct alignas(alignof(long double)) Foo2
{
    // put your definition here
}; 
 
struct Empty {};
 
struct alignas(64) Empty64 {};
 
#define SHOW(expr) std::cout << #expr << " = " << (expr) << '\n'
 
int main()
{
    SHOW(alignof(char));
    SHOW(alignof(int*));
    SHOW(alignof(Foo));
    SHOW(alignof(Foo2));
    SHOW(alignof(Empty));
    SHOW(alignof(Empty64));
}

可能的输出

alignof(char) = 1
alignof(int*) = 8
alignof(Foo) = 4
alignof(Foo2) = 16
alignof(Empty) = 1
alignof(Empty64) = 64

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
CWG 1305 C++11 type-id 不能表示对元素类型完整但边界未知的数组的引用
但元素类型完整
允许

[编辑] 参考文献

  • C++23 标准 (ISO/IEC 14882:2024)
  • 7.6.2.6 Alignof [expr.alignof]
  • C++20 标准 (ISO/IEC 14882:2020)
  • 7.6.2.5 Alignof [expr.alignof]
  • C++17 标准 (ISO/IEC 14882:2017)
  • 8.3.6 Alignof [expr.alignof]
  • C++14 标准 (ISO/IEC 14882:2014)
  • 5.3.6 Alignof [expr.alignof]
  • C++11 标准 (ISO/IEC 14882:2011)
  • 5.3.6 Alignof [expr.alignof]

[编辑] 另请参阅

对齐要求 限制对象可以分配的地址
alignas (C++11) 指定变量的存储应按特定量对齐
(说明符)[编辑]
获取类型的对齐要求
(类模板) [编辑]
C 文档 用于 _Alignof, alignof 运算符