字節序 大端模式、小端模式

大端格式:ide

在這種格式中,字數據的高字節存儲在低地址中,而字數據的低字節則存放在高地址中,如圖2.1所示: 函數

 

 

小端格式:post

與大端存儲格式相反,在小端存儲格式中,低地址中存放的是字數據的低字節,高地址存放的是字數據的高字節。如圖2.2所示:測試

 

 

 請寫一個C函數,若處理器是Big_endian的,則返回0;如果Little_endian的,則返回1spa

解答: orm

int checkCPU( )blog

{ 內存

    { ci

           union w 開發

           {  

                  int  a;

                  char b;

           } c;

           c.a = 1;

           return(c.b ==1);

    }

}

剖析:

嵌入式系統開發者應該對Little-endianBig-endian模式很是瞭解。例如,16bit寬的數0x1234Little-endian模式CPU內存中的存放方式(假設從地址0x4000開始存放)爲:

內存地址

0x4000

0x4001

存放內容

0x34

0x12

而在Big-endian模式CPU內存中的存放方式則爲:

內存地址

0x4000

0x4001

存放內容

0x12

0x34

 

32bit寬的數0x12345678Little-endian模式CPU內存中的存放方式(假設從地址0x4000開始存放)爲:

內存地址

0x4000

0x4001

0x4002

0x4003

存放內容

0x78

0x56

0x34

0x12

而在Big-endian模式CPU內存中的存放方式則爲:

內存地址

0x4000

0x4001

0x4002

0x4003

存放內容

0x12

0x34

0x56

0x78

聯合體union的存放順序是全部成員都從低地址開始存放。

=============== 呵呵 仍是附上 另外一段代碼吧,摘自一個開源項目 ====

int  big_endian (void)

 

     {
       union{
          long l;
          char c[sizeof(long)];
       }u;
 
       u.l = 1;
       return  (u.c[sizeof(long) - 1] == 1);
     }
  

 

有時候,用C語言寫程序時須要知道是大端模式仍是小端模式。 所謂的大端模式,是指數據的低位保存在內存的高地址中,而數據的高位,保存在內存的低地址中;所謂的小端模式,是指數據的低位保存在內存的低地址中,而數據的高位保存在內存的高地址中。爲何會有大小端模式之分呢?這是由於在計算機系統中,咱們是以字節爲單位的,每一個地址單元都對應着一個字節,一個字節爲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,則是小端......
相關文章
相關標籤/搜索