计算机大小端
大端模式
所謂的大端模式,是指數據的高位,保存在內存的低地址中,而數據的低位,保存在內存的高地址中,這樣的存儲模式有點兒類似于把數據當作字符串順序處理:地址由小向大增加,而數據從高位往低位放;
??????? 例子: 0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000 0000440: b484 6c4e 004e ed00 0000 0000 0100 0000 在大端模式下,前16位應該這樣讀: e684
????????記憶方法: 地址的增長順序與值的增長順序相反
小端模式
所謂的小端模式,是指數據的高位保存在內存的高地址中,而數 據的低位保存在內存的低地址中,這種存儲模式將地址的高低和數據位權有效地結合起來,高地址部分權值高,低地址部分權值低,和我們的邏輯方法一致。
??????? 例子: 0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000 0000440: b484 6c4e 004e ed00 0000 0000 0100 0000 在小端模式下,前16位應該這樣讀: 84e6
????????記憶方法: 地址的增長順序與值的增長順序相同
為什么有大小端模式之分
為什么會有大小端模式之分呢?這是因為在計算機系統中,我們是以字節為單位的,每個地址單元都對應著一個字節,一個字節為 8bit。但是在C語言中除了8bit的char之外,還有16bit的short型,32bit的long型(要看具體的編譯器),另外,對于位數大于 8位的處理器,例如16位或者32位的處理器,由于寄存器寬度大于一個字節,那么必然存在著一個如何將多個字節安排的問題。因此就導致了大端存儲模式和小端存儲模式。例如一個16bit的short型x,在內存中的地址為0x0010,x的值為0x1122,那么0x11為高字節,0x22為低字節。對于 大端模式,就將0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。小端模式,剛好相反。我們常用的X86結構是小端模式,而KEIL C51則為大端模式。很多的ARM,DSP都為小端模式。有些ARM處理器還可以由硬件來選擇是大端模式還是小端模式。
測試編輯器屬哪種模式
下面這段代碼可以用來測試一下你的編譯器是大端模式還是小端模式:
???short int x;
???char x0,x1;
???x=0x1122;
???x0=((char*)&x)[0]; //低地址單元
???x1=((char*)&x)[1]; //高地址單元 若x0=0x11,則是大端; 若x0=0x22,則是小端......
???上面的程序還可以看出,數據尋址時,用的是低位字節的地址。
???linux操作系統中對大小端的判斷:
???static union?
???{?
????? ? char c[4];
??????? unsigned long l;?
???} endian_test = { { 'l', '?', '?', 'b' } };
???#define ENDIANNESS ((char)endian_test.l)
???(如果ENDIANNESS=’l’表示系統為little endian,為’b’表示big endian )。
???使用C語言判斷處理器的大小端
???[1]int checkCPU()?
???{
????union w?
????{?
?????int a;?
?????char b;?
????} c;
????c.a = 1;
????return (c.b == 1); /* 1 : little-endian */ /* 0 : big-endian */
???}
???#include<stdio.h> ?
???int main(void)
???{
????int a = 0x12345678;
????unsigned char *p =?
????(unsigned char *)&a;
????if (0x78 == *p)
????{
?????printf("littleend\n");
????}
????else
????{
?????printf("bigend\n");
????}
????return 0;
???} ??????
???
總結
- 上一篇: 广发银行信用卡网上银行转账还款多久到账
- 下一篇: 深入理解.bin文件和.nb0文件的结构