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
|