typedef struct tagSocketData {
BYTE nSize;
BYTE nType;
DWORD nDataSize;
DWORD nIndex;
SOCKET socket;
DWORD nDataLength;
} SOCKETDATA, *LPSOCKETDATA;SOCKETDATA sd;
sd.nSize = sizeof(SOCKETDATA); //本来应该是18, 可却是20sizeof(SOCKETDATA) = 20, 本来是18字节的大小
实际大小却是20
可存为文件的时候却是按照18字节的大小存储应该怎么解决??
BYTE nSize;
BYTE nType;
DWORD nDataSize;
DWORD nIndex;
SOCKET socket;
DWORD nDataLength;
} SOCKETDATA, *LPSOCKETDATA;SOCKETDATA sd;
sd.nSize = sizeof(SOCKETDATA); //本来应该是18, 可却是20sizeof(SOCKETDATA) = 20, 本来是18字节的大小
实际大小却是20
可存为文件的时候却是按照18字节的大小存储应该怎么解决??
解决方案 »
- VC 6.0下如何使用CXimage库? 求解!
- 求助,利用WIN32 API向表单中的CELL赋值
- error C2311: 'class _com_error' : is caught by '...' on line 44这个问题该如何解决
- 在菜单项目中加入对话框为什么出现“undeclared identifier”
- 增量调整Checksum的算法,谁能给点信息?
- 在view类里怎么传一个数给对话框??
- 在不同进程中发送消息传送参数
- 找不到MFC42D.dll,怎么办??急!
- 关于CTestView(很急,在线等待中......)
- 请教
- 如何动态的得到屏幕显示,告急!!!100分
- 当我新建一个基于CObject类的新类的的时候,基类选项里没有CObject或者Cobject?
{
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)
// the value set with /Zp or
// #pragma pack
typedef struct tagSocketData {
BYTE nSize;
BYTE nType;
DWORD nDataSize;
DWORD nIndex;
SOCKET socket;
DWORD nDataLength;
} SOCKETDATA, *LPSOCKETDATA;
#progma pack(pop,1)就可以了~