1.结构体的大小并不是简单的成员大小的相加,而是有两个规则要符合的。
规则一:结构体成员的偏移量必须是该成员的大小的整数倍(0被认为是任何数的整数倍)
穿插一点补充:记住偏移量是指当前成员前面成员所占的字节数,例如下面Test1那里,int前面已 经有char了,按道理说其偏移量是1的,但为了对齐,必须在加多3形成4与int对齐,所以1+3 = 4,int的偏移量为4,最后一个char的偏移量为4+4为8,8+1为9,那么9是不是这个结构体的大小呢,显然不是,其实是12,继续看原则二。
规则二:结构体大小必须是结构体成员大小的整数倍(数组,结构体除外)
对齐方式虽然浪费了内存空间,但是对齐方式提高了计算机对程序的访问效率
任何一个结构体的大小都要符合上述两个原则。
struct Test1{
char i; //1
int ch; //4 +3
char k; //1
};
2.接下来我们分类看一下结构体的大小的计算方式
(1)简单类
struct Test1
{
char ch; //1
int i; //4 +3
char chr;//1
};//这时结构体的大小为12
由于最后一个char的偏移量是8,但8+1 = 9并不是int大小的整数倍,
所以要继续往后移,到12时就合适了是所有成员大小的整数倍了,所以其大小为12
(2)简单类2
struct Test2
{
char che; //1
char cha; //1
int i; //4 +2
};//这时候结构体大小为8
由于int前面的偏移量为2,但2并不是int大小的整数倍,所以要加2偏移量变为4,所以4+4 = 8,
8即是1的倍数,也是4的倍数,所以这个结构体大小为8
(3)结构体含数组1
struct Test3
{
/*这时候这个结构体的大小是136,因为数组不要求偏移量是
其大小整数倍,数组大小直接加上前面的成员大小即可*/
int studentId; //4
char name[128]; //128
int scores; //4
};
这时候这个结构体的大小是136,因为数组不要求偏移量是其大小整数倍,
数组大小直接加上前面的成员大小即可,由于132是最后int的倍数,所以其大小为132+4 = 136
切记,结构体的大小不需要是数组大小的整数倍
(4)结构体数组2
struct Test4
{
结构体的大小不要求是数组的整数倍,只要是其他成员大小的整数倍即可
char id; //1
int num