- 1、普通结构体计算大小
- 2、嵌套结构体计算大小
- 3、修改对齐数的结构体
结果为:12
结构体中,类型占用空间最大的,作为对齐数
下面结构体中,int 是4 作对齐数
计算方式: 起始位置:(结构体第一个数起始位置是从0开始) a: 1 * 0 = 0 b: 2 * 1 = 2 c: 4 * 1 = 4 d: 2 * 4 = 8 从位置下标0开始: a:起始位置是0,占用1个字节,放在0的位置 b:占用2个字节,乘0肯定不行,0的地方已经放a了,所以乘1,等于2,起始位置 2开始放,占两个字节放两位 c:4个字节,乘0肯定不行,乘1,起始位置是4开始,因为对齐数是4 所以换行, d:2个字节,只有乘4才可以,前面都已经有数了,起始位置8开始,放两个, 最后填充所以大小是12 a * b b c c c c d d * *
int main(void)
{
struct T
{
char a;
short b;
int c;
short d;
}t;
printf("%dn",sizeof(t));
return 0;
}
2、嵌套结构体计算大小
嵌套结构体,先找两个结构体最大的字节数,作为结构体的对齐数
对齐数是:8
偏移量计算:
e:1*0 = 0
f:f*1 = 4
g:8*1 = 8
h:2*8 = 16
嵌套的结构体起点坐标:需要加上个结构体的总和,
a:24+4*0 = 24
b: 24+8*1 = 32
c: 24+4*4 = 40
e e * * f f f f
g g g g g g g g
h h * * * * * *
a a a a * * * *
f f f f * * * *
struct A
{
int a;
double b;
float c;
};
struct
{
char e[2];
int f;
double g;
short h;
struct A i;
}B;
3、修改对齐数的结构体
#pragma pack 要是修改的对齐数(只能是2的n次方),大于结构体中最大类型,结构体中最大类型,作对齐数
起始位置计算方式不一样: 超过2哥字节,以2字节来计算 a:2*0 = 0 b:2*2 =4 id: 2*6=12 a a a a b b b b b b b b id id
#pragma pack(2) // 指定对齐单位为2个字节
struct
{
int age;
double b;
short id;
}te;



