结构体大小
内存对齐
·结构体成员存放的地址要能整除改成员本身的大小
1、前面所有成员的大小相加应该是当前成员大小的倍数。
2、整个结构体的大小应该是该结构体中单个最大成员大小的倍数。
下面是对结构体大小的计算
(1)
struct A
{
char a;//1+3
int b;//4
};//8
结构体含有一个char类型,一个int类型。因为要考虑内存对齐,所以结构体A的大小为8。
因为要内存对齐,所以char类型需要时int类型的倍数因此要给1+3。
(2)
struct B
{
int a;//4+4
double b;//8
float *c;//4
};//20+4
struct C
{
int a;//4
float *b;//4
double c;//8
};//16
通过结构体B和结构体C看出,不同数据类型存放顺序不同,结构体的大小也就不同。
struct D
{
int a;//4
char b;//1
};//5+3
这种情况就属于上面所说的第二种,整个结构体的大小应该是该结构体中单个最大成员大小的倍数。4是1的倍数但4+1不是4的倍数所以要给5+3。
(3)
struct E
{
char a;//1+3
struct EE
{
int b;
long c;
}d;//8
};//12
这个是结构体中套结构体,结构体EE中int型和long类型都是4 所以结构体EE的大小是8;结构体E的是char类型1,对于1结构体套结构体看的是结构体里面的大小。所以是1+3 是4的倍数。最后的大小为1+3+4+4。
(4)
struct D
{
char a;//1
struct DD
{
int b;
long c;
};//没有定义变量
};
这个例子是在结构体里面没有定义变量,所以它不能定义在结构体的大小。因此这个结构体的大小为char型1。