1
|
写出下列程序在X86上的运行结果 |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
struct mybitfields { unsigned short a
: 4; unsigned short b
: 5;
unsigned short c
: 7; }
test void main( void ) { int i; test.a
= 2; test.b
= 3;
test.c
= 0; i
= *(( short *)&test); printf ( "%d\n" ,
i); // 输出50 }
这个题的为难之处呢,就在于前面定义结构体里面用到的冒号,如果你能理解这个符号的含义,那么问题就很好解决了。
这里的冒号相当于分配几位空间,也即在定义结构体的时候,分配的成员a 4位的空间, b 5位,c 7位,一共是16位,正好两个字节。
下面画一个简单的示意:
变量名 位数
test 15 14 13 12 11 10 9 |8 7 6 5 4 |3 2 1 0
test.a |0 0 1 0
test.b |0 0 0 1 1 |
test.c 0 0 0 0 0 0 0 | // 注意地址依次从低到高排列
在执行i=*((short *)&test); 时,取从地址&test开始两个字节(short占两个字节)的内容转化为short型数据,
即为0x0032,再转为int型为0x00000032,即50
我是这么理解的,结构体中a,b,c从低地址到高地址分别占4,5,7位,main中赋值以后a=2,b=3,c=0.
又输出为short型为test的低16位的数,所以,为2+16*3=50
|