#pragma pack 与#pragma pack(push,1)
2010-12-16 19:26
211 查看
#pragma pack是指定数据在内存中的对齐方式,
在C语言中,结构是一种复合数据类型,其构成元素既可以是基本数据类型(如int、long、float等)的变量,也可以是一些复合数据类型(如数组、结构、联合等)的数据单元。在结构中,编译器为结构的每个成员按其自然对界(alignment)条件分配空间。各个成员按照它们被声明的顺序在内存中顺序存储,第一个成员的地址和整个结构的地址相同
(1) #pragma pack(1)
作用:调整结构体的边界对齐,让其以一个字节对齐;
#pragma pack(1) 使结构体按1字节方式对齐
例如1:
struct sample
{
char a;
double b;
};
若不用#pragma pack(1)和#pragma pack()括起来,则sample按编译器默认方式对齐(成员中size最大的那个)。即按8字节(double)对齐,则sizeof(sample)==16.成员char a占了8个字节(其中7个是空字节)
若用#pragma pack(1),则sample按1字节方式对齐sizeof(sample)==9.(无空字节)
比较节省空间啦,有些场和还可使结构体更易于控制
(2) #pragma pack(push,1)
这是给编译器用的参数设置,有关结构体字节对齐方式的设置
大概是指把原来对齐方式设置压栈,并设新的设置为1
例 2:下面的结构各成员空间分配情况:
struct test
{
char x1;
short x2;
float x3;
char x4;
};
结构的第一个成员x1,其偏移地址为0,占据了第1个字节。第二个成员x2为short类型,其起始地址必须2字节对界,因此,编译器在x2和x1之间填充了一个空字节。结构的第三个成员x3和第四个成员x4恰好落在其自然对界地址上,在它们前面不需要额外的填充字节。在test结构中,成员x3要求4字节对界,是该结构所有成员中要求的最大对界单元,因而test结构的自然对界条件为4字节,编译器在成员x4后面填充了3个空字节。整个结构所占据空间为12字节。更改C编译器的缺省字节对齐方式
在缺省情况下,C编译器为每一个变量或是数据单元按其自然对界条件分配空间。一般地,可以通过下面的方法来改变缺省的对界条件:
· 使用伪指令#pragma pack (n),C编译器将按照n个字节对齐。
· 使用伪指令#pragma pack (),取消自定义字节对齐方式。
另外,还有如下的一种方式:
· __attribute((aligned (n))),让所作用的结构成员对齐在n字节自然边界上。如果结构中有成员的长度大于n,则按照最大成员的长度来对齐。
· __attribute__ ((packed)),取消结构在编译过程中的优化对齐,按照实际占用字节数进行对齐。
以上的n = 1, 2, 4, 8, 16... 第一种方式较为常见。
转自 http://blog.csdn.net/zhanghefu/archive/2010/08/15/5814157.aspx
在C语言中,结构是一种复合数据类型,其构成元素既可以是基本数据类型(如int、long、float等)的变量,也可以是一些复合数据类型(如数组、结构、联合等)的数据单元。在结构中,编译器为结构的每个成员按其自然对界(alignment)条件分配空间。各个成员按照它们被声明的顺序在内存中顺序存储,第一个成员的地址和整个结构的地址相同
(1) #pragma pack(1)
作用:调整结构体的边界对齐,让其以一个字节对齐;
#pragma pack(1) 使结构体按1字节方式对齐
例如1:
struct sample
{
char a;
double b;
};
若不用#pragma pack(1)和#pragma pack()括起来,则sample按编译器默认方式对齐(成员中size最大的那个)。即按8字节(double)对齐,则sizeof(sample)==16.成员char a占了8个字节(其中7个是空字节)
若用#pragma pack(1),则sample按1字节方式对齐sizeof(sample)==9.(无空字节)
比较节省空间啦,有些场和还可使结构体更易于控制
(2) #pragma pack(push,1)
这是给编译器用的参数设置,有关结构体字节对齐方式的设置
大概是指把原来对齐方式设置压栈,并设新的设置为1
例 2:下面的结构各成员空间分配情况:
struct test
{
char x1;
short x2;
float x3;
char x4;
};
结构的第一个成员x1,其偏移地址为0,占据了第1个字节。第二个成员x2为short类型,其起始地址必须2字节对界,因此,编译器在x2和x1之间填充了一个空字节。结构的第三个成员x3和第四个成员x4恰好落在其自然对界地址上,在它们前面不需要额外的填充字节。在test结构中,成员x3要求4字节对界,是该结构所有成员中要求的最大对界单元,因而test结构的自然对界条件为4字节,编译器在成员x4后面填充了3个空字节。整个结构所占据空间为12字节。更改C编译器的缺省字节对齐方式
在缺省情况下,C编译器为每一个变量或是数据单元按其自然对界条件分配空间。一般地,可以通过下面的方法来改变缺省的对界条件:
· 使用伪指令#pragma pack (n),C编译器将按照n个字节对齐。
· 使用伪指令#pragma pack (),取消自定义字节对齐方式。
另外,还有如下的一种方式:
· __attribute((aligned (n))),让所作用的结构成员对齐在n字节自然边界上。如果结构中有成员的长度大于n,则按照最大成员的长度来对齐。
· __attribute__ ((packed)),取消结构在编译过程中的优化对齐,按照实际占用字节数进行对齐。
以上的n = 1, 2, 4, 8, 16... 第一种方式较为常见。
转自 http://blog.csdn.net/zhanghefu/archive/2010/08/15/5814157.aspx
相关文章推荐
- #pragma pack(push) 和#pragma pack(pop) 以及#pragma pack()
- #pragma pack(push,1) & #pragma pack(pop)
- #pragma pack(n) 和 #pragma pack(push,1)
- #pragma pack(push,1)与#pragma pack(1)的区别
- #pragma pack(push,1)与#pragma pack(pop)
- #pragma pack(push,1)与#pragma pack(1)的区别
- #pragma pack(push,1) & #pragma pack(pop)
- #pragma pack(push,1) (pop)
- #pragma pack(push,1) & #pragma pack(pop)
- 细说 #pragma pack(n)*** #pragma pack(push,1)与#pragma pack(1)的区别
- #pragma pack(push,1) 与 #pragma pack(1)的区别
- 释析#pragma pack(push,n) #pragma pack(n) #pragma pack() #pragma pack(pop)
- #pragma pack(push,1)与#pragma pack(1)的区别
- #pragma pack(push,1)与#pragma pack(1)的区别
- #pragma pack(push,1) & #pragma pack(pop)
- #pragma pack (push,1) and #pragma pack(pop)
- #pragma pack(push,1)与#pragma pack(1)的区别
- AMD 平台 VC2005下 慎用#pragma pack(push,1)来进行字节对齐
- #pragma pack(1) and #pragma pack(push,1)是什么意思
- #pragma push_macro #pragma pop_macro和#pragma pack的用法