结构体在内存中的存储也叫结构体的内存对齐,这也是一个热门考点。
1. 对齐规则
- 结构体的第一个成员对齐到和结构体变量其实位置偏移量为0的地址处。
- 其他成员要对齐到对齐数的整数倍地址处。
- 结构体总大小为最大对齐数(结构体每个成员变量都有一个对齐数,所有对齐数中最大的)的整数倍。
- 如果嵌套了结构体情况下,嵌套的结构体成员对齐到自己的成员中最大对齐数的整数倍处,结构体的整体大小就是所有对齐数(含嵌套结构体成员的最大对齐数)的整数倍。
对齐数 = 编译器默认的一个对齐数与该成员变量大小的较小值。
-VS的默认对齐数为8
-Linux 中 gcc 默认没有对齐数
1.2 为什么存在内存对齐
1. 平台原因(移植原因):
不是所有的硬件平台都能访问任意地址上的任意数据的;某些硬件平台只能在某些地址处取某些特定类型的数据,否则抛出异常
2.性能原因:
数据结构(尤其是栈)应尽可能在自然边界上对齐。因为,为了访问未对齐的数据,处理器需要做两次访问,而对齐的访问内存只需要一次。
总体来说:结构体的内存对齐是一种拿时间换空间的做法。
2. 练习
练习1:
为什么两个结构体的成员变量大小都是相同的,只是位置不同,但是两个结构体的总大小却不一样呢?
这就涉及到结构体在内存中的对齐了
按照对齐规则s1和s2在内存中是这样存储的
练习2:
结构体的嵌套问题
嵌套不同的是,嵌套的结构体的对齐数为其成员变量的最大对齐数(参考第4条规则),同学们自己来算一下
3. 修改默认对齐数
如果觉得编译器或者处理后的对齐数不合适,可以手动修改默认对齐数
#pragma 这个预处理指令,可以改变编译器的默认对齐数。
记得用完之后要修改回默认对齐数。
制作不易,若对您有帮助请家人们三连支持,感谢!!!