C语言中结构体内存对齐规则
对齐规则:
- 内存偏移为该数据类型的最小整数倍
- 总体占用内存为结构体中最大数据类型的整数倍
举个:
首先,要搞清楚每一种数据类型占用内存为多少,在这里,是针对64位Linux(macOs)为例的
NSLog(@"char:%zd",sizeof(char));
NSLog(@"double:%zd",sizeof(double));
NSLog(@"long:%zd",sizeof(long));
NSLog(@"long long:%zd",sizeof(long long));
NSLog(@"char *:%zd",sizeof(char *));
NSLog(@"int:%zd",sizeof(int));
NSLog(@"short:%zd",sizeof(short));
输出结果为:
Test[5517:167810] char:1
Test[5517:167810] double:8
Test[5517:167810] long:8
Test[5517:167810] long long:8
Test[5517:167810] char *:8
Test[5517:167810] int:4
Test[5517:167810] short:2
typedef struct {
char *a;
char b;
char c;
short e;
int aa;
long bbb;
short dddd;
struct {
int ccc;
short bb;
char *ee;
};
char ddf;
}SL;
分析过程
int main(int argc, const char * argv[]) {
@autoreleasepool {
NSLog(@"%zd",sizeof(SL));
}
return 0;
}
输出结果:
2019-12-15 22:35:17.371774+0800 Test[5079:150310] 56
Program ended with exit code: 0
从这里可以看出,总体占用内存空间为56
个字节
分析:
- 根据上面占用字节可知:
char * a
指针类型占用8
个字节 - 根据上面占用字节可知:
char b
占用1
个字节,所以,到这里,占用字节数为9
- 同2中可知,
char c
占用1
个字节所以,到这里,占用字节总数为10
- 根据上面占用字节可知:
short e
占用2
个字节,这里要注意需要对齐2的最小整数倍,在这里,因为已经到了10,正好是2的最小整数倍,所以,从10开始占用2个字节,加起来应该是12
个字节 - 根据上面占用字节可知:
int aa
占用4
个字节,要对齐4的最小整数倍,12正好是4的整数倍,所以,从12开始占用4个字节,到这里一共占用字节数为16
- 根据上面占用字节可知:
long bbb
占用8
个字节,这里要对齐8的最小整数倍,现在已经是16了,正好是8的整数倍,所以从16开始,占用8个字节,到这里为24
-
short ddd
占用2
个字节,对齐2的整数倍,从24开始占用2
个字节,到这里一共占用26
- 结构体中分析方法和正常分析方法一个逻辑:
int ccc
占用4
个字节,要对齐4的已占用内存的最小整数倍,4*8 = 32,所以要从32
开始占用4个字节,最后为36
-
short bb
,占用2
个字节,对齐2的整数倍,从36开始,占用2个字节,最后为38
-
char * ee
占用8
个字节,要对齐8的整数倍,从40
开始,占用8个字节,最后为48
- 最后一个
char ddf
,占用1
个字节,到这里为49
最后输出结果为什么是56
呢,根据上述对齐原则,输出结果为结构体中最大占用字节的整数倍,结构体中最大占用字节为8
,现在总占用字节数为49
,所以输出为8的整数倍56
网友评论