规则一.: 每个成员变量在其结构体内的偏移量都是成员变量类型的大小的倍数。
规则二: 如果有嵌套结构体,那么内嵌结构体的第一个成员变量在外结构体中的偏移量,是内嵌结构体中那个数据类型大小最大的成员变量的倍数。
规则三: 整个结构体的大小要是这个结构体内数据类型大小最大的成员变量的倍数。如果有内嵌结构体,那么取内嵌结构体中数据类型大小最大的成员变量作为计算外结构体整体大小的依据。
例子
typedef struct TEST{
int na;
char cb;
char cc;
int nd;
char cf;
struct TT{
int ng;
long long llh;
}tt;
char ci;
}test;
图一
如上图所示,根据规则一,nd在结构体内的位置必须满足是其自身数据类型大小的整数倍,且倍数要取满足条件的最小倍数。因为nd前三个成员变量总大小是6Bytes,nd作为int类型,其数据类型大小是4Bytes,满足条件的最小倍数是2,所以nd在结构体中的偏移量是8,故填充2Bytes。
根据规则二,ng作为内嵌结构体的第一个成员变量,它在外结构体中的偏移量要满足——其内嵌结构体中最大数据类型大小的倍数。在计算cf偏移量后,当前偏移量是13,而内嵌结构体中最大数据类型为long long,其大小为8,ng的偏移量必须是8的倍数,且取大于13的最小倍数,即2。所以ng前要填充3Bytes。
根据规则三,计算完ci后,当前偏移量是33。如果要满足test结构体的大小是其中最大数据成员类型大小的倍数,在此例中是内嵌结构体的成员变量llh,即8的倍数。所以要填充7Bytes。
参考
CSDN博客:https://blog.csdn.net/zhanghow/article/details/55262988