C语言中 #prama pack(1) 是什么呢

Python016

C语言中 #prama pack(1) 是什么呢,第1张

意思是把数据对齐到1的倍数,那也就是取消掉对齐了

所谓对齐就是安排数据让它的起始地址在一个合适的位置上,避免用2条语句读入数据的情况。 比如下面的结构

struct a{

char c

long l

}

c占用了1个字节(第0字节), 但是l默认会被安排在 4-7字节,整个占用8字节。

如果先写了 这句 pragma pack(1) , 结果就是 c占用第0字节, 而l安排在1-4字节,整个占用5字节。 虽然省地方, 可是读入l就费劲了, 得读两次到寄存器,再挪到一起去, 要慢不少

还有,这个不是c的标准内容而是vc的增加内容。 其他编译器也有类似的调整对齐机制,但是是不一样的语法

这是因为编译时存在字节对齐的原因,字节对齐主要是为了提高内存数据读取速度。如果你想要让结果等于实际大小,你可以设置字节对齐大小如

#pragma pack(1)

取消设置

#pragma pack()

字节对齐的规则如下:

结构体的大小等于其最大成员的整数倍;

结构体成员的首地址相对于结构体首地址的偏移量是其类型大小的整数倍。

比如double型成员的首地址相对于结构体首地址的偏移量应该是8的倍数;

满足前两条规则后,编译器会在结构体成员之后进行字节填充。

设置结构体的边界对齐为1个字节,也就是所有数据在内存中是连续存储的。

比如你在C语言中定义下面这样的结构体:

struct s {

char ch

int i

}

然后在主函数中写一句:printf("%d", sizeof(struct s))

也就是输出结构体s所占的字节数

你觉得输出结果会是多少呢?

我们知道,char型占用1个字节,int型占4个字节,那么输出的结果是5吗?

答案是否定的。你可以自己试一下,输出结果为8。

为什么会这样呢?这是因为编译器为了让程序跑得跟快,减少CPU读取数据的指令周期,对结构体的存储进行了优化。实际上第一个char型成员虽然本来只有1个字节,但实际上却占用掉了4个字节,为的是让第二个int型成员的地址能够被4整除。因此实际占用的是8个字节。

而#pragma pack(1)让编译器将结构体数据强制连续排列,这样的话,sizeof(struct s)输出的结果就是5了。