sizeof运算符在C++中用于编译时计算类型或对象的字节大小,其值受内存对齐规则影响;结构体成员按自身对齐要求布局,总大小为最大成员对齐数的整倍数,编译器可能插入填充字节;例如struct{char;int;char;}因对齐需12字节而非6字节;成员顺序、#pragma pack指令、虚函数表指针及空结构体(大小为1)均影响结果;常用于数组元素计数、序列化和内存分配,结合alignof与offsetof可精准分析内存布局。

在C++中,sizeof 是一个编译时运算符,用于获取数据类型或对象所占用的内存字节数。它常用于数组、结构体、类等类型的内存布局分析,尤其在涉及结构体内存对齐时,理解 sizeof 的计算规则至关重要。
sizeof基本用法
sizeof 可以作用于以下几种情况:
- 基本数据类型:如 sizeof(int)、sizeof(char)
- 变量名:int a; sizeof(a)
- 数组:int arr[10]; sizeof(arr) 返回整个数组字节数
- 结构体或类:sizeof(MyStruct)
注意:sizeof 在编译阶段求值,不会执行表达式,也不会调用构造函数。
结构体内存对齐规则
C++为了提高CPU访问内存的效率,会对结构体成员进行内存对齐。不同平台和编译器可能有不同的对齐策略,但通常遵循以下通用规则:
立即学习“C++免费学习笔记(深入)”;
- 每个成员按其自身大小对齐(如 int 按4字节对齐,double 按8字节对齐)
- 结构体总大小必须是其最大成员对齐数的整数倍
- 编译器可能在成员之间插入填充字节(padding)以满足对齐要求
例如:
char a; // 占1字节,偏移0
int b; // 占4字节,需从4字节边界开始 → 偏移补到4
char c; // 占1字节,偏移8
};
// 总大小 = 1 + 3(padding) + 4 + 1 + 3(padding) = 12 字节
sizeof(Example) 结果为 12,而非直观的 6。
影响sizeof计算的因素
以下因素会影响结构体的 sizeof 计算结果:
- 成员顺序:将大类型放在前面可减少填充。比如把 char 放在 int 后面会增加 padding
- #pragma pack 指令:可手动设置对齐方式,如 #pragma pack(1) 关闭对齐,使结构体紧凑
- 继承与虚函数:含虚函数的类会包含虚函数表指针(vptr),增加对象大小
- 空结构体:在C++中,空结构体大小为1字节,确保每个实例有唯一地址
常见应用场景
sizeof 常用于:
- 计算数组元素个数:int arr[10]; count = sizeof(arr)/sizeof(arr[0]);
- 序列化/反序列化时确定数据块大小
- 动态内存分配时指定所需空间
- 调试内存布局问题,验证对齐行为
基本上就这些。掌握 sizeof 和内存对齐机制,有助于写出更高效、跨平台兼容性更强的C++代码。实际开发中建议使用 alignof、offsetof 等标准工具辅助分析对齐细节。










