结构体中可以定义的数据类型:
1. 基本类型
2. 上面已经出现过的数据类型,比如说上面已经定义过的结构体
3. 指向自己的指针
由于内存对齐的问题,各个数据类型放的位置不同就会导致结构体的大小不一样。
偏移量:结构体中的偏移量就是结构体成员和结构体变量的地址之差,比如说第一个结构体成员的偏移量就是0,第二个结构成员的偏移量就是第一个结构体成员的大小,假如第一个成员的是int b;那么第二个结构体成员变量的偏移量就是4。
计算结构体大小的规则:
1. 每一个成员的偏移量都必须是该成员的倍数。
2. 结构体的大小必须是该结构体字节数最大成员的倍数。
示例 1:
struct A{
char a;
short b;
int c;
};
分析:第一个成员的偏移量都是0;一般可以不看,a的大小为1,所以成员b的偏移量为1,b的大小为2,1不是2的倍数,所以应该将1+1,成为2的倍数,成员c的偏移量就为1+1+2,是成员c的倍数,现在就符合计算结构体大小的第一条:改成员的偏移量是该成员大小的倍数,还有第二条规则:结构体大小是结构体最大成员的倍数,结构体的大小就是各个成员之和,a;2,b:2,c:4加起来就是8,该结构最大成员为c大小为4,满足第二个条件,所以该结构体的倍数就是8。
示例 2:
struct Data{
char a;
int b;
int64_t c; 该数据类型是有符号的占64位的整形数据类型
char d;
}
分析:成员a的偏移量就不用看了,上面有说每一个结构体第一个成员的偏移量都为0;但他的大小是1,也就是成员b的偏移量,成员b的大小是4,1不是4的倍数,所以a的大小1应该加上3,就是4,成员3的偏移量是8,成员c的大小是8,成员c的偏移量是成员c大小的倍数,就不用增加大小,成员d的偏移量是16,成员d的大小是1,偏移量是成员大小的倍数,现在就符合计算结构体大小的第一条:改成员的偏移量是该成员大小的倍数,还有第二条规则:结构体大小是结构体最大成员的倍数,最大成员为c,大小是8,结构体的大小就是各个成员之和,a:4,b:4,c:8,d:1所有的加起来就是17,但是17不是8的倍数,所以应该将17+7就是24,所以该结构体的大小就是24。