大端(Big Endian)與小端(Little Endian)詳解

來源:互聯網
上載者:User

大端(Big Endian)與小端(Little Endian)詳解

【大端(Big Endian)與小端(Little Endian)簡介】
Byte Endian是指位元組在記憶體中的組織,所以也稱它為Byte Ordering,或Byte Order。
     對於資料中跨越多個位元組的對象, 我們必須為它建立這樣的約定:
(1) 它的地址是多少?
(2) 它的位元組在記憶體中是如何組織的?
    針對第一個問題,有這樣的解釋:
    對於跨越多個位元組的對象,一般它所佔的位元組都是連續的,它的地址等於它所佔位元組最低地址。(鏈表可能是個例外, 但鏈表的地址可看作鏈表頭的地址)。
    比如: int x, 它的地址為0x100。 那麼它佔據了記憶體中的Ox100, 0x101, 0x102, 0x103這四個位元組(32位系統,所以int佔用4個位元組)。
    上面只是記憶體位元組組織的一種情況: 多位元組對象在記憶體中的組織有一般有兩種約定。 考慮一個W位的整數。
    它的各位表達如下:[Xw-1, Xw-2, ... , X1, X0],它的
    MSB (Most Significant Byte, 最高有效位元組)為 [Xw-1, Xw-2, ... Xw-8];
    LSB (Least Significant Byte, 最低有效位元組)為 [X7,X6,..., X0]。
    其餘的位元組位於MSB, LSB之間。

LSB和MSB誰位於記憶體的最低地址, 即誰代表該對象的地址?
這就引出了大端(Big Endian)與小端(Little Endian)的問題。
如果LSB在MSB前面, 既LSB是低地址, 則該機器是小端; 反之則是大端。
DEC (Digital Equipment Corporation,現在是Compaq公司的一部分)和Intel的機器(X86平台)一般採用小端。
IBM, Motorola(Power PC), Sun的機器一般採用大端。
當然,這不代表所有情況。有的CPU即能工作於小端, 又能工作於大端, 比如ARM, Alpha,摩托羅拉的PowerPC。 具體情形參考處理器手冊。

具體這類CPU是大端還是小端,應該和具體設定有關。
(如,Power PC支援little-endian位元組序,但在預設配置時是big-endian位元組序)
一般來說,大部分使用者的作業系統(如windows, FreeBsd,Linux)是Little Endian的。少部分,如MAC OS ,是Big Endian 的。
所以說,Little Endian還是Big Endian與作業系統和晶片類型都有關係。

Linux系統中,你可以在/usr/include/中(包括子目錄)尋找字串BYTE_ORDER(或
_BYTE_ORDER, __BYTE_ORDER),確定其值。BYTE_ORDER中文稱為位元組序。這個值一般在endian.h或machine/endian.h檔案中可以找到,有時在feature.h中,不同的作業系統可能有所不同。

對於一個數0x1122
使用Little Endian方式時,低位元組儲存0x22,高位元組儲存0x11
而使用Big Endian方式時, 低位元組儲存0x11, 高位元組儲存0x22

經一網友指正,才知道,上面的描述,是不準確的.

想了下,覺得如下描述可能更合適:

使用Little Endian方式儲存資料時,資料的LSB相對最沒意義的資料位元,存放在低地址位置,這裡的LSB也就是22了.也即,

低地址儲存0x22, 高地址儲存0x11

而使用Big Endian方式儲存資料時,資料的MSB最有意義的資料位元,存放在低地址位置,這裡的MSB也就是11了.也即

低地址儲存0x11, 高地址儲存0x22

助記:

1)所謂MSB (Most Significant Byte),名字很複雜,不知是否有人沒搞懂,反正我開始看到這個詞時候,就很糊塗,有點不完全理解.其實簡單說MSB就是,一個數字中,最重要的那位,

舉例來說,12004,中文讀作,一萬兩千零四,那最高位的1,就表示了一萬,此處就稱作MSB,最有意義的位.

2)一般常見的資料存放區,用文字寫出來的時候,其內容書寫格式,多數是從低地址到高地址.

舉例,一個16進位數是 0x11 22 33, 而存放的位置是

地址0x3000 中存放11

地址0x3001 中存放22

地址0x3002 中存放33

連起來就寫成地址0x3000-0x3002中存放了資料0x112233.

而這種存放和表示方式,正好符合大端.

解釋的有點亂,希望有人能看懂.

如果還有哪裡有誤,還請各位繼續指正.謝謝.

【用函數判斷系統是Big Endian還是Little Endian】
bool IsBig_Endian()
//如果位元組序為big-endian,返回true;
//反之為   little-endian,返回false
{
    unsigned short test = 0x1122;
    if(*( (unsigned char*) &test ) == 0x11)
       return TRUE;
else
    return FALSE;

}//IsBig_Endian()

以上內容,整理自:

如何判斷系統是Big Endian還是Little Endian?
http://jlingmei.spaces.live.com/blog/cns!77254CCC13222C11!391.entry?wa=wsignin1.0

判斷機器位元組儲存順序是big endian還是little endian
http://hi.baidu.com/cppyun/blog/item/9625c8396d5ff7f33b87ce33.html

動態判斷cpu位元組序是big-endian還是little-endian
http://chongyanglee.bokee.com/4919503.html

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.