结构体的大小受内存对齐规则影响,不是成员变量大小的简单相加。1. 每个成员变量的起始地址必须是其类型大小的整数倍;2. 结构体总大小必须是内部最大成员对齐值的整数倍;3. 编译器会自动填充字节以满足对齐要求;4. 成员顺序、编译器设置(如#pragma pack(n))、虚函数机制等因素也会影响最终大小;5. 可通过sizeof()查看结构体实际大小,通过offsetof()宏查看成员偏移量来验证内存布局。

结构体的大小并不是简单地把每个成员变量的大小加起来,而是受内存对齐规则影响。搞清楚这一点,对于优化程序性能、理解数据在内存中的布局非常关键。

C++中结构体的大小计算遵循几个基本的内存对齐规则:

举个例子:
立即学习“C++免费学习笔记(深入)”;
struct Example {
char a; // 1字节
int b; // 4字节
short c; // 2字节
};按照上面的规则:

char a 占1字节,放在偏移0的位置没问题;int b,它需要从4的倍数地址开始,因此前面要填充3个字节;short c,它需要从2的倍数地址开始,刚好可以紧跟在b之后;除了基本的对齐规则外,还有几个容易被忽略的因素会影响结构体的大小:
char 放在 int 后面,而不是开头,可能节省空间。#pragma pack(n) 指令来手动控制对齐方式,n可以是1、2、4等,表示按n字节对齐。最直接的方法就是使用 sizeof() 运算符:
cout << sizeof(Example) << endl;
这会输出结构体在当前平台下的实际大小。
如果你想更深入地了解结构体的内存布局,可以用调试器查看内存分布,或者用 offsetof() 宏查看每个成员的偏移量:
#include <cstddef> cout << offsetof(Example, b) << endl;
此外,也可以通过手动插入 char dummy; 或者使用 std::aligned_storage 来模拟结构体内存布局并验证填充情况。
基本上就这些了。只要记住,结构体大小不是成员大小的简单相加,而是一个受对齐规则、编译器策略和成员顺序共同影响的结果。
以上就是C++中如何计算结构体的大小 内存对齐原则详解的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号