http://blog.sina.com.cn/s/blog_6a1837e90100y6mv.html 2012 大端模式所謂的大端模式,是指數(shù)據(jù)的高位,保存在內(nèi)存的低地址中,而數(shù)據(jù)的低位,保存在內(nèi)存的高地址中,這樣的存儲(chǔ)模式有點(diǎn)兒類似于把數(shù)據(jù)當(dāng)作字符串順序處理:地址由小向大增加,而數(shù)據(jù)從高位往低位放; 例子: 0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000 0000440: b484 6c4e 004e ed00 0000 0000 0100 0000 在大端模式下,前16位應(yīng)該這樣讀: e684 記憶方法: 地址的增長順序與值的增長順序相反小端模式所謂的小端模式,是指數(shù)據(jù)的高位保存在內(nèi)存的高地址中,而數(shù)據(jù)的低位保存在內(nèi)存的低地址中,這種存儲(chǔ)模式將地址的高低和數(shù)據(jù)位權(quán)有效地結(jié)合起來,高地址部分權(quán)值高,低地址部分權(quán)值低,和我們的邏輯方法一致。 例子: 0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000 0000440: b484 6c4e 004e ed00 0000 0000 0100 0000 在小端模式下,前16位應(yīng)該這樣讀: 84e6 記憶方法: 地址的增長順序與值的增長順序相同為什么有大小端模式之分為什么會(huì)有大小端模式之分呢?這是因?yàn)?font color="#0E0BFF">在計(jì)算機(jī)系統(tǒng)中,我們是以字節(jié)為單位的,每個(gè)地址單元都對(duì)應(yīng)著一個(gè)字節(jié),一個(gè)字節(jié)為 8bit。但是在C語言中除了8bit的char之外,還有16bit的short型,32bit的long型(要看具體的編譯器),另外,對(duì)于位數(shù)大于8位的處理器,例如16位或者32位的處理器,由于寄存器寬度大于一個(gè)字節(jié),那么必然存在著一個(gè)如何將多個(gè)字節(jié)安排的問題。因此就導(dǎo)致了大端存儲(chǔ)模式和小端存儲(chǔ)模式。例如一個(gè)16bit的short型x,在內(nèi)存中的地址為0x0010,x的值為0x1122,那么0x11為高字節(jié),0x22為低字節(jié)。對(duì)于 大端模式,就將0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。小端模式,剛好相反。我們常用的X86結(jié)構(gòu)是小端模式,而KEIL C51則為大端模式。很多的ARM,DSP都為小端模式。有些ARM處理器還可以由硬件來選擇是大端模式還是小端模式。測試編輯器屬哪種模式下面這段代碼可以用來測試一下你的編譯器是大端模式還是小端模式:short int x; char x0,x1; short x=0x1122; x0=((char*)&x)[0]; //低地址單元 x1=((char*)&x)[1]; //高地址單元 若x0=0x11,則是大端; 若x0=0x22,則是小端...... 上面的程序還可以看出,數(shù)據(jù)尋址時(shí),用的是低位字節(jié)的地址。linux操作系統(tǒng)中對(duì)大小端的判斷:static union { char c[4]; unsigned long l; } endian_test = { { 'l', '?', '?', 'b' } }; #define ENDIANNESS ((char)endian_test.l) (如果ENDIANNESS=’l’表示系統(tǒng)為little endian,為’b’表示big endian )。使用C語言判斷處理器的大小端int checkCPU() {} |
|