struct 关于sizeof的大小问题

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

typedef struct tagSocketData {

BYTE nSize;

BYTE nType;

DWORD nDataSize;

DWORD nIndex;

SOCKET socket;

DWORD nDataLength;

} SOCKETDATA, *LPSOCKETDATA;

SOCKETDATA sd;

sd.nSize = sizeof(SOCKETDATA); //本来应该是18, 可却是20

sizeof(SOCKETDATA) = 20, 本来是18字节的大小

实际大小却是20

可存为文件的时候却是按照18字节的大小存储

应该怎么解决??

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

看看这个

struct tagHDD

{

char c1;

DWORD n;

}HDD;

long n=sizeof(HDD);//n会返回8,为什么,真怪。

回复人: bluebohe(薄荷)

这不怪,就怪在缺省的对齐方式上。

在结构中,编译器为结构的每个成员按其自然对界(alignment)条件分配空间;各个成员按照它们被声明的顺序在内存中顺序存储,第一个成员的地址和整个结构的地址相同。在缺省情况下,C编译器为每一个变量或是数据单元按其自然对界条件分配空间。

例如,下面的结构各成员空间分配情况。

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编译器的缺省分配策略

一般地,可以通过下面的方法改变缺省的对界条件:

? 使用伪指令#pragma pack ([n])

#pragma pack ([n])伪指令允许你选择编译器为数据分配空间所采取的对界策略。

例如,在使用了#pragma pack (1)伪指令后,test结构各成员的空间分配情况就是按照一个字节对齐了,格式如下:

#pragma pack(push) //保存对齐状态

#pragma pack(1)

//定义你的结构

//…………

#pragma pack(pop)

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

在编译选项中可以设置:菜单中“工程”-->“设置”, 弹出一个“project setting”对话框。然后选择“C/C++”标签--->在“Y分类”中选择“Code Generation”--->在“Struct member alignment”中选择“1 Byte”。

重新编译。ok了!!

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

#pragma pack(push,1)

typedef struct tagSocketData {

BYTE nSize;

BYTE nType;

DWORD nDataSize;

DWORD nIndex;

SOCKET socket;

DWORD nDataLength;

} SOCKETDATA, *LPSOCKETDATA;

#progma pack(pop,1)

就可以了~

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航