结构体里的“位域”(bit-field)结构

首先看一个题目:

 #include <iostream>
using namespace std;
#include <string.h>
typedef struct AA{
int b1:;//第一个字节的低5位,即b4:b0
int b2:;//b6:b5
}AA; int main(int argc, char** argv) {
AA aa;
char cc[];
strcpy(cc,"0123456789abcdefghijklmnopqrstuvwxyz");
memcpy(&aa,&cc,sizeof(AA));
cout<<aa.b1<<endl;
cout<<aa.b2<<endl;
return ;
}

请问,上述代码的输出结果? 答案是-16,1.

第12行,将字符串“0123456789abcdefghijklmnopqrstuvwxyz”赋给字符数组cc.第13行,将大小为sizeof(AA),也就是4个字节(因为只定义了一个int型)的数据赋给aa指向的内存空间。因为cc的前4个字节数据为“0123”,也就是0x30313233,所以aa指向的内存空间的前4个字节数据即为0x30313233,其中第一个字节的二进制为:00110000.而aa.b1是第一个字节的低5位,即10000(-16),同理aa.b2是01(1)

现将上述代码的第11、12行改为:

int cc=0x30313233;

那么,上述代码的输出结果为?答案是-13,1.(在x86平台下)

这是为什么呢?因为x86是小端存储,在执行第13行拷贝的时候,是先将int cc的低位字节的数据拷贝到aa里,所以aa的前4个字节为:0x33323130,其第一个字节为00110011.

上一篇:javascript之attribute 和 property


下一篇:Web Service和WCF的到底有什么区别