處理器的大小端

爲什麼會有大小端模式之分呢?這是因爲在計算機系統中,我們是以字節爲單位的,每個地址單元都對應着一個字節,一個字節爲 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處理器還可以由硬件來選擇是大端模式還是小端模式。

          所謂的大端模式,是指數據的低位(就是權值較小的後面那幾位)保存在內存的高地址中,而數據的高位,保存在內存的低地址中,這樣的存儲模式有點兒類似於把數據當作字符串順序處理:地址由小向大增加,而數據從高位往低位放;

 

   所謂的小端模式,是指數據的低位保存在內存的低地址中,而數 據的高位保存在內存的高地址中,這種存儲模式將地址的高低和數據位權有效地結合起來,高地址部分權值高,低地址部分權值低,和我們的邏輯方法一致。

        C語言判斷處理器的大小端:

判斷處理器的大小端

int checkCPU()
{
 {
  union w
  {  
   int  a;
   char b;
  } c;
  c.a = 1;
  return (c.b == 1);
 }
}

//////////////////////////

如果輸出結果是1,就是小端的,如果是0,就是大端的。

C語言爲共用體c分配了4個字節的內存空間,可以想象成4個格子,變量a佔4個,變量b只佔低地址的一個。
c.a = 1;賦值後,
如果是小端,則最低位地址的那個格子存放1,其它3個格子都存放0。(1即十六進制0001)
如果是大端,則最高位地址的那個格子存放1,其它3個格子都存放0。

補充一下大端模式和小端模式的定義:
大端模式:字數據的高字節存儲在低地址中,字數據的低字節存儲在高地址中。
小端模式:字數據的高字節存儲在高地址中,字數據的低字節存儲在低地址中。

 

////////////////////////

最好用等長數組判斷
union {
  int a;
  char b[sizeof(int)];
}test;

test.b[0]=1;
test.b[1]=2;
test.b[2]=3;
test.b[3]=4;

對於大端的,這個a就是0x04030201,對於小端,則應該是0x01020304,判斷a就知道是大端小端了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章