结构体字节对齐

#include <stdio.h>
#pragma pack(2)
struct T...{
    char i;
    int d;
    char ii;
};
#pragma pack()
int main(int argc,char * argv[])
...{
    printf("%d ",sizeof(struct T));
    return 0;
}    最后输出的结果为:8。
这个表示是按照2字节来对齐数据,首先分配2字节给成员变量i,分配完成后,还剩一字节,(zj add补0)没法容纳成员变量d,此时会再分配2字节,还是容纳不下,就在分配两字节,这是刚好容纳下成员变量d,此时就已分配6字节,最后一个变量ii还是分配2字节,所以最终结果是8字节

 

------------

#pragma pack作用
[ 2007-3-30 3:50:00 | By: romanticode ]
通过#pragma pack(n)改变C编译器的字节对齐方式
在C语言中,结构是一种复合数据类型,其构成元素既可以是基本数据类型(如int、long、float等)的变量,也可以是一些复合数据类型(如数组、结构、联合等)的数据单元。在结构中,编译器为结构的每个成员按其自然对界(alignment)条件分配空间。各个成员按照它们被声明的顺序在内存中顺序存储,第一个成员的地址和整个结构的地址相同。

     例如,下面的结构各成员空间分配情况:
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... 第一种方式较为常见。
 
-------------
 
booming think:
从以上两个网友回答得出结论:
1.每次按自然对界的字节数分配一段空间,而元素的分配一定是按照数据对齐原则(即数据所在的内存地址必须是该数据长度的整数倍)
2.当结构体内元素都小于处理器位数的时候,以结构体中最长的数据元素为对齐单位。
    反之则按处理器位数为对齐单位。
3.如果有#program pack(n)的情况下,则按n
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值