寫出下列程序在X86上的運行結果。 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 ",i); }
在表示一個多字節對象的字節順序的時候,通常有兩個規則: 小端法:在存儲器中,按照從最低有效字節到最高有效字節的順序存儲對象,即最低有效位在最前端; 大端法:在存儲器中,按照從最高有效字節到最低有效字節的順序存儲對象,即最高有效位在最前端;
Inter的機器采用小端法,而大部分的機器都采用大端法。
有兩點是確定的: 1.多字節對象在存儲器中被存儲為連續的字節順序; 2.對象的地址為所使用字節序列中最小的地址。
例如:假設一個類型為int的變量x,其值為0x01234567,被存儲在存儲器的0x100,0x101,0x102,0x103的位置上。 那么,x的地址為0x100,即&x的值就是100,小端法時從0x100到0x103這四個字節中分別存放的值為67,45,23,01,而在大端法中這四個字節中依次存放的是:01,23,45,67。
最高有效位和最低有效位,最高有效字節和最低有效字節: 如果一個多字節數x有w位,可以表示為【xw-1,xw-2,。。。x1, x0】其中,xw-1為最高位,x0為最低位。如果這些位能被組織成字節,那么Xw-1到Xw-8為最高有效字節,X7到X0為最低有效字節。
這個題的為難之處呢,就在于前面定義結構體里面用到的冒號,如果你能理解這個符號的含義,那么問題就很好解決了。這里的冒號相當于分配幾位空間,也即在定義結構體的時候,分配的成員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。輸出的結果就是50。當然,這里還涉及到字節及位的存儲順序問題,后面再說。
|