#pragma pack(n)

规则:

程序员可以通过预编译命令#pragma pack(n),n=1,2,4,8,16来让一个结构体进行按着规定的字节进行对齐,其实之所以有内存字节对齐机制,就是为了最大限度的减少内存读取次数。我们知道CPU读取速度比内存读取速度快至少一个数量级,所以为了节省运算花费时间,只能以牺牲空间来换取时间了.

  1. 数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员的对齐按照#pragma pack指定的数值和这个数据成员自身长度中,比较小的那个进行。
  2. 结构(或联合)的整体对齐规则:在数据成员完成各自对齐之后,结构(或联合)本身也要进行对齐,对齐将按照#pragma pack指定的数值和结构(或联合)最大数据成员长度中,比较小的那个进行。
  3. #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


genius_platform软件平台开发】第十三点:内存对齐 #pragma Pack_字节对齐

#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)