结构体内存对齐原则
2018-03-23 12:35
253 查看
1.结构体对齐含义
Ø 结构体的存储结构Ø 结构体的总大小(sizeof)2.结构体对齐原则
Ø 结构体是按照成员定义顺序存储的Ø 结构体第一个成员从offset为0的地址开始存储Ø 成员存储起始地址必须满足:min(“成员自身类型的模数”,“#pragam pack(x)”) 的整数倍,否则补齐直到满足Ø 结构体的总大小必须满足:min(“结构体内部最大成员模数”," #pragam pack(x)")的整数倍,否则补齐直到满足Ø 当结构体作为其他结构体成员时,成员模数为”结构体内部最大成员模数“32位编译器: char :1个字节char*(即指针变量): 4个字节(32位的寻址空间是2^32, 即32个bit,也就是4个字节。同理64位编译器)
short int : 2个字节
int: 4个字节
unsigned int : 4个字节
float: 4个字节
double: 8个字节
long: 4个字节
long long: 8个字节
unsigned long: 4个字节
64位编译器: char :1个字节
char*(即指针变量): 8个字节
short int : 2个字节
int: 4个字节
unsigned int : 4个字节
float: 4个字节
double: 8个字节
long: 8个字节
long long: 8个字节
unsigned long: 8个字节举例说明例1:无“#pragma pack(x)”宏定义 typedef struct{ char a; char b; double c; short d;}Test;存储结构:
因为无”#pragma pack()“宏定义:min("成员自身类型的模数","#pragma pack(x)")=“成员自身类型的模数”;min(”结构体内部最大成员模数“,"#pragma pack(x)")="结构体内部最大成员模数";成员a:模数为1,为第一个成员,offset地址为“Addr0”;成员b:模数为1,“Addr1”满足为1的整数倍条件;成员c:模数为4,”Addr2“不满足为4的整数倍条件,应取”Addr4“,并补齐”Addr2“、"Addr3";成员d:模数为2,”Addr8“满足为2的整数倍条件;sizeof(Test):结构体内部最大成员模数为4,目前结构体长度为10,10不是4的整数倍,所以还需补齐2个字节,总大小为12;例2:有“#pragma pack(x)”宏定义#pragma pack(2)typedef struct{ char a; char b; double c; short d;}Test;#pragma pack()存储结构:
成员a:模数为1,为第一个成员,offset地址为“Addr0”; 成员b:模数为1,min("成员自身类型的模数","#pragmapack(2)")=1,“Addr1”满足为1的整数倍条件;成员c:模数为4,min("成员自身类型的模数","#pragmapack(2)")=2,”Addr2“满足为2的整数倍条件;成员d:模数为2,min("成员自身类型的模数","#pragmapack(2)")=2,”Addr6“满足为2的整数倍条件;sizeof(Test):结构体内部最大成员模数4,min(结构体内部最大成员模数,"#pragmapack(2)")= 2,目前结构体长度为8,满足2的整数倍条件;
相关文章推荐
- C 结构体内存对齐原则
- C 结构体内存对齐原则
- C 结构体内存对齐原则
- 结构体内存对齐规则总结-整体单个排列/成员之间没有边界只有最后的填充/最后是最大类型整数倍
- 结构体内存对齐
- 自定义类型中结构体、枚举等,结构体内存对齐相关要点总结
- C编译器编译结构体时的对齐原则
- 内存对齐模式与结构体
- 内存的字节对齐及结构体的sizeof计算
- C++ 结构体内存对齐
- 结构体的定义声明、内存对齐
- 结构体内存对齐
- C中结构体和字节流的互换及内存对齐
- 结构体拾遗补缺1:内存对齐与sizeof
- 关于结构体内存对齐
- 内存对齐全攻略--涉及位域的内存对齐原则
- sizeof(结构体)和内存对齐以及位域
- C++中结构体的大小与内存对齐
- 结构体在内存中的对齐规则
- 结构体中的内存对齐操作