1. 程式人生 > >一個判斷機器位元組序(big endian/little endian)的小程式

一個判斷機器位元組序(big endian/little endian)的小程式

大端(Big Endian)與小端 (Little Endian)
Byte Endian是指位元組在記憶體中的組織,所以也稱它為Byte Ordering。

     對於資料中跨越多個位元組的物件, 我們必須為它建立這樣的約定
:
(1) 它的地址是多少
?
(2) 它的位元組在記憶體中是如何組織的
?
     針對第一個問題,有這樣的解釋
:
     對於跨越多個位元組的物件,一般它所佔的位元組都是連續的, 它的地址等於它所佔位元組最低地址。(連結串列可能是個例外, 但連結串列的地址可看作連結串列頭的地址)。

比如: int x, 它的地址為0x100。 那麼它佔據了記憶體中的Ox100, 0x101, 0x102, 0x103這四個位元組。
上面只是記憶體位元組組織的一種情況: 多位元組物件在記憶體中的組織有一般有兩種約定。 考慮一個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之間。

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