struct tag_Program0
{
int a; //4字节
char b; //1字节
double c; //8字节
long int d; //4字节
};
struct tag_Program1
{
int a; //4字节
char b; //1字节
double c; //8字节
long int d; //4字节
struct tag_Program0 PP; //24字节
}P;
第一个结构体tag_Program6的存储结构如图所示
其实看结构体最大的成员多大,然后从第一个成员开始算
再看一下这个结构体
struct tag_Program2
{
int a; //4字节
char b; //1字节
long int d; //4字节
};
比较简单的,一共12字节,怎么算,4+4+4
怎么算:
1.看最大字节为4
2.从上往下算
3.a为4字节,刚好对齐,不用凑。
4.b为1字节,先看下一个是什么,是4字节,1+4超过了最大4字节,所以b自己凑一个4字节,只要加个3字节就好了。如果下一个成员是一个字节呢?1+1还是不够4字节,怎么办,凑到4字节再加2个字节就好了。
5.再继续往下看d,4字节,刚好和最大字节一样,所以不用凑。
所以大小总和 = a的4字节+b的1字节+为b凑到4字节的3字节+d的4字节 = 12字节
无论有没有嵌套一个结构体,实质是一样,就是要和最大字节的成员对齐!!!!就是凑整齐了。