结构体的对齐规则
1.第一个成员在与结构体变量偏移量为0的地址处。
2.其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。
对齐数 = 编译器默认的一个对齐数与该成员大小的较小值。
VS中默认的值为8
3.结构体总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。
4.如果嵌套了结构体的情况,嵌套的结构体对齐到自己的最大对齐数的整数倍处,结构体的整体大小就是所有最大对齐数(含嵌套结构体的对齐数)的整数倍。
练习1
第一个成员c1对齐到偏移量为0的地址处。
第二个成员i是int,大小为4个字节,而VS的对齐数是8,所以该成员的对齐数为4,因此i要对齐到4的倍数的地址处,即偏移量为4的地址处(4、5、6、7),而偏移量为1、2、3的地址处的空间就被浪费了。
第三个成员c2是char,大小为1个字节,因此对齐数为1,要对齐到1的倍数的地址处,即偏移量为8的地址处。
三个成员的对齐数分别为1、4、1,最大对齐数为4,因此结构体的总大小应该为4的整数倍,而上述计算出的大小为9,不是4的整数倍,往后数,12才是4的整数倍,因此需要再浪费3个内存空间,最终结构体的大小为12,如下图所示。
练习2
第一个成员c1对齐到0偏移量处。
第二个成员c2的对齐数为1,对齐到1偏移量处。
第三个成员i的对齐数为4,对齐到4偏移量处。
三个成员的最大对齐数为4,因此结构体的总大小应为4的整数倍,为8。
从上述两个例子也可以看出,在设计结构体的时候,既要满足对齐,又要节省空间,就要让占用空间小的成员尽量集中在一起。