#pragma pack(n)
规则:
程序员可以通过预编译命令#pragma pack(n),n=1,2,4,8,16来让一个结构体进行按着规定的字节进行对齐,其实之所以有内存字节对齐机制,就是为了最大限度的减少内存读取次数。我们知道CPU读取速度比内存读取速度快至少一个数量级,所以为了节省运算花费时间,只能以牺牲空间来换取时间了.
- 数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员的对齐按照#pragma pack指定的数值和这个数据成员自身长度中,比较小的那个进行。
- 结构(或联合)的整体对齐规则:在数据成员完成各自对齐之后,结构(或联合)本身也要进行对齐,对齐将按照#pragma pack指定的数值和结构(或联合)最大数据成员长度中,比较小的那个进行。
- #pragma pack(4) // 设定为 4 字节对齐 struct test char m1; double m4; int m3; }; #pragma pack() // 恢复默认对齐状态 // 以上结构体的大小为 16:
例子
#pragma pack(1)
struct node{
char f;
int e;
short int a;
char b;};
struct node n;
printf("%d\n",sizeof(n));
// 输出:8
#pragma pack(push,1)与#pragma pack(1)的区别
这是给编译器用的参数设置,有关结构体字节对齐方式设置, #pragma pack是指定数据在内存中的对齐方式。
#pragma pack (n) 作用:C编译器将按照n个字节对齐。
#pragma pack () 作用:取消自定义字节对齐方式。
#pragma pack (push,1) 作用:是指把原来对齐方式设置压栈,并设新的对齐方式设置为1个字节对齐
#pragma pack(pop) 作用:恢复对齐状态
因此可见,加入push和pop可以使对齐恢复到原来状态,而不是编译器默认,可以说后者更优,但是很多时候两者差别不大
如:
#pragma pack(push) //保存当前对齐状态
#pragma pack(4) //设定为4字节对齐
相当于 #pragma pack (push,4)