根据以下条件进行计算:
1、 结构体的大小等于结构体内最大成员大小的整数倍
2、 结构体内的成员的首地址相对于结构体首地址的偏移量是其类型大小的整数倍,比如说double型成员相对于结构体的首地址的地址偏移量应该是8的倍数。
1、 结构体的大小等于结构体内最大成员大小的整数倍
2、 结构体内的成员的首地址相对于结构体首地址的偏移量是其类型大小的整数倍,比如说double型成员相对于结构体的首地址的地址偏移量应该是8的倍数。
3、 为了满足规则1和2编译器会在结构体成员之后进行字节填充!
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
class
A
{
int
a; //4
short
b; //2 +2 (满足条件2)
int
c; //4
char
d; //1 +3 (满足条件1)
};
4+2+2+4+1=13 + 3(填充字节) = 16
class
B
{
double
a; //8
short
b; // 2 +2 (满足条件2)
int
c; // 4
char
d; // 1 +7 (满足条件1)
};
8+2+2+4+1 = 17 + 7(填充字节) = 24
|
在32位机器上用gcc编译以上代码,求sizeof(A),sizeof(B)分别是16、24。
解释:
A中,a占4个字节,b本应占2个字节,但由于c占4个字节,为了满足条件2,b多占用2个字节,为了满足条件1,d占用4个字节,一共16个字节。
B 中,a占8个字节, b占2个字节,但由于c占4个字节,为了满足条件2,b多占用2个字节 ,
即abc共占用8+4+4=16个字节, 为了满足条件1,d将占用8个字节,一共24个字节。
B 中,a占8个字节, b占2个字节,但由于c占4个字节,为了满足条件2,b多占用2个字节 ,
即abc共占用8+4+4=16个字节, 为了满足条件1,d将占用8个字节,一共24个字节。