一、记住以下四条计算准则
①:第一个成员在与结构体变量偏移量为0的地址处。
②:其他成员变量要对齐到某个数字(对齐数)的整数倍的地址处。对齐数=编译器默认的一个对齐数与该成员大小的较小值,在VS环境下默认值为8,在Linux环境下默认值为4。
③:结构体的总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。
④:如果嵌套了结构体的情况,被嵌套的结构体对齐到其自身对齐数的整数倍处(结构体的对齐数就是其内部成员中最大的对齐数),此时结构体的整体大小就是所有最大对齐数(含被嵌套结构体的对齐数)的整数倍。
注:约定为32位系统,即char 1字节、short 2字节、int 4字节,指针是地址4个字节
二、举例子
#include <stdio.h>
struct s1
{
char c1; // 1
int i; // 4
char c2; // 1
};
int main()
{
struct s1 s1;
printf("%d\n", sizeof(s1));
}
结果是12
c1是第一个成员,在偏移量位0的地方占一个字节,用红色的方框表示,i是第二个成员,对齐数是4(对齐数 = 编译器默认的一个对齐数 与 该成员大小的较小值。vs默认对齐数是8,int大小4个字节),所以i要对齐到4的整数倍处,偏移量4的位值,占4个字节的大小,用橙色的4个方框表示,现在偏移量已经到达8,最后一个成员是c2,对齐数是1,任何正整数都是1的倍数,所以c2从偏移量位8的位置开始占1个字节,再处理完后发现一共只有9个字节,这与结果还是不一样,这时就需要用到规则3(结构体总大小为最大对齐数(每个成员变量都有一个对齐数)的整数倍。),上述结构体的最大对齐数位4,而此时已经有9个字节,9显然不是4的倍数,浪费掉一个字节,依次类推,发现12是4的倍数**,12就是结构体的总大小**