這裡涉及大小端的問題,我記為

“小高高,小弟弟(低低)”,就是:

“小端模式,是指資料的高位儲存在記憶體的高地址中,資料的低位儲存在記憶體的低地址中”

這是記小端模式的,有點黃,不過好記!那麼大端模式就和這個相反嘍!!~~

接下來就看一道面試題:

#include<stdio.h>

struct mybitfields
{
	unsigned short a:4;
	unsigned short b:5;
	unsigned short c:7;	
}test;

int main()
{
	int i;
	test.a=2;
	test.b=3;
	test.c=0;
	i=*((short *) &test);
	printf("i=%d\n",i);
	printf("sizeof (short)= %d\n",sizeof(short));
	return 0;
}
a佔4個bit、b佔5個bit、c佔7個bit,總共16bit,大小和short的一樣大!執行完下面的三條語句之後
test.a=2;
test.b=3;
test.c=0;
記憶體分佈如下:

這裡x86是小端模式,所以資料分散式上面的,而不是我們理所當然的0010 00011 0000000!

i=*((short *) &test);
這句話執行之後:把test整個轉換成一個short的變數,然後再賦值給int型的i,i能夠容納*((short*) &test),那麼i的值就是

那麼i的值就是1*32+1*16+2=50嘍!計算式以0x(00.....00110010)計算哦!~~

以上執行的結果是在x86平臺下,編譯器是mingw。