有关SizeOf的大小问题

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,为什么,真怪。  

原因在缺省的对齐方式上。  
在结构中,编译器为结构的每个成员按其自然对界(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)  

        也可以在编译选项中设置。vc中选择菜单“Project”-->“Settings”,弹出一个“project  setting”对话框。然后选择“C/C++”标签--->在“Category”中选择“Code Generation”--->在“Struct member alignment”中选择“1 Byte”。

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值