结构体成员内存分配的规则:
1、各成员变量在存放的时候根据在结构中声明的顺序依次申请空间。
2、系统按照对齐方式调整成员变量的存储位置,空缺的字节会自动填充。
各成员变量存放的起始地址相对于结构体的起始地址的偏移量必须为该变量的类型所占用的字节数的倍数。
类型 对齐方式(变量存放的起始地址相对于结构体的起始地址的偏移量)
char 偏移量必须为sizeof(char)即1的倍数
int 偏移量必须为sizeof(int)即4的倍数
float 偏移量必须为sizeof(float)即4的倍数
double 偏移量必须为sizeof(double)即8的倍数
Short 偏移量必须为sizeof(short)即2的倍数
3、为了确保结构的大小为结构的字节边界数(该结构体中占用最大空间的类型所占用的字节数)的倍数,所以在为最后一个成员变量申请空间后,还会根据需要自动填充空缺的字节。
例:s1
按照结构体内的顺序依次申请存储空间。
Char占用1个字节,因是结构体的第一个成员,故占用结构体的首地址0。
Int 占用4个字节,int存放的位置必须是首地址的倍数,地址1不是4的倍数,故int在4处存放,并占用4个字节。
Char和Int之间的内存因不是4的倍数,故自动填充3个空缺,以达到4的倍数。
Double占用8个字节,char和int已占用8个字节,故地址8是8的倍数,double存放在地址8开始的位置,并占用8个字节。
分配完所有成员变量的内存后,计算总得内存字节大小。
S1占用的内存为16个字节,再进行最大字节边界数确认。
S1中最大字节数为double的8各字节,S1的总字节16恰好是8的倍数,故末尾不用填充空缺。
如果分配后S1的总字节数不是8的倍数,则要按照8的最小倍数填充空缺的字节。
例,如果S1最后占用20个字节,因不是8的倍数,此时最接近8的倍数是24,故需要填充4个空缺,此时S1的总字节数就不是20,而是24.