前言
我们知道结构体内存对齐字节可以通过#pragma pack(n) 的方式来指定。
但是,有没有想过一个问题,某些时候我想4字节对齐,有些时候我又想1字节或者8字节对齐,那么怎么解决这个问题呢?
此时,#pragma pack(push) 和#pragma pack(pop) 以及#pragma pack()应运而生。
看测试代码:(说明,64位GCC,默认8字节对齐)
屏蔽了的代码先别看,只看这个结构体,在默认8字节对齐的方式下,sizeof大小为24个字节,这不再做分析,之前随笔分析过了。
pragma pack()
然后我加上强制4字节对齐之后:
那么现在,我再新建一个结构体B,内容和结构体C一样,只是对齐方式向分别采取不同的方式:
#include <stdio.h>
#pragma pack(4)
struct C {
double d;
char b;
int a;
short c;
};
#pragma pack()
struct B {
double d;
char b;
int a;
short c;
};
像上面那样处理之后,输出:先打印结构C,再打印结构B
这说明了,在强制4字节对齐之后,我加上#pragma pack() ,能够让程序恢复默认对齐(这里是8字节)状态。
#pr