您的位置:首页 > 其它

#pragma pack(n)的用法

2016-06-21 13:04 267 查看
设置结构体的边界对齐为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了。
更改C编译器的缺省字节对齐方式在缺省情况下,C编译器为每一个变量或是数据单元按其自然对界条件分配空间。一般地,可以通过下面的方法来改变缺省的对界条件:     · 使用伪指令#pragma pack (n),C编译器将按照n个字节对齐。     · 使用伪指令#pragma pack (),取消自定义字节对齐方式。另外,还有如下的一种方式:     · __attribute((aligned (n))),让所作用的结构成员对齐在n字节自然边界上。如果结构中有成员的长度大于n,则按照最大成员的长度来对齐。     · __attribute__ ((packed)),取消结构在编译过程中的优化对齐,按照实际占用字节数进行对齐。使用心得:#pragma pack (n) 虽然指定了按照N个字节对齐,但是当结构体内部,默认用m对齐的,而且m<n,n那么这个结构体就按照m个字节对齐而不是n字节对齐。< span="" style="word-wrap: break-word;">下面是例子:#pragma pack(8)typedef struct  {    char  i;    char  j;}s1;typedef struct  {    short i;    s1   k;    char j;}s2;#pragma pack()sizeof(s1) = 2;sizeof(s2) = 6;他们都不是按照8个字节对齐的。

                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  c