结构体和共用体的内存对齐

编译器按照成员列表的顺序一个接一个地给每个成员分配内存。

只有当存储成员时需要满足正确的边界对齐要求时,成员时间才可能出现用于填充的额外内存空间。

系统禁止编译器在一个结构的起始位置跳过几个字节来满足边界对齐要求,因此所有结构的起始位置必须是结构中边界要求最严格的数据所要求的位置。

这段话来自 C和指针,意思是存储结构体变量的地址必须是结构体最长元素的整数倍。

结构体嵌套结构体时的内存对齐还是以最长元素作为边界对齐要求,而不是以结构体变量的长度:

可以发现,结构变量的首地址是4的整数倍,而不是的整数倍。

 

联合体的对齐方式和结构体一样

联合体的长度是最长成员的长度

如果联合体的成员是数组并且数组的长度是联合体中是最长的,那么联合体的长度是数组的长度,而不是单个数组元素的长度;联合体的成员是结构体变量并且结构体的长度是联合体中是最长的,那么联合体的长度是结构体变量的长度而不是结构体成员变量的长度。

长度12

结构体变量的长度为12个字节,在联合体成员中是最长的,所以联合体的大小12个字节。按照4对齐(int型)

猜你喜欢

转载自blog.csdn.net/aabb7012086/article/details/82556086