作業系統中的大頭小頭位元組序

2021-09-21 13:57:17 字數 1415 閱讀 7124

網路位元組序與主機位元組序

不同的cpu有不同的位元組序型別 這些位元組序是指整數在記憶體中儲存的順序 這個叫做主機序

最常見的有兩種

1. little endian(小頭):將低序位元組儲存在起始位址

2. big endian(大頭):將高序位元組儲存在起始位址

二進位制編碼: 0x高位|低位  

fe ff : 大頭,最直觀

ff fe:小頭,需要顛倒

le little-endian

最符合人的思維的位元組序

位址低位儲存值的低位

位址高位儲存值的高位

怎麼講是最符合人的思維的位元組序,是因為從人的第一觀感來說

低位值小,就應該放在記憶體位址小的地方,也即記憶體位址低位

反之,高位值就應該放在記憶體位址大的地方,也即記憶體位址高位

be big-endian

最直觀的位元組序

位址低位儲存值的高位

位址高位儲存值的低位

為什麼說直觀,不要考慮對應關係

只需要把記憶體位址從左到右按照由低到高的順序寫出

把值按照通常的高位到低位的順序寫出

兩者對照,乙個位元組乙個位元組的填充進去

例子:在記憶體中雙字0x01020304(dword)的儲存方式

記憶體位址

4000 4001 4002 4003

le 04 03 02 01

be 01 02 03 04

例子:如果我們將0x1234abcd寫入到以0x0000開始的記憶體中,則結果為

big-endian   little-endian

0x0000   0x12       0xcd

0x0001   0x23       0xab

0x0002   0xab       0x34

0x0003   0xcd       0x12

用sublime顯示漢字 「嚴」在ansiunicodeunicode big endianutf-8編碼方式下對應的機器碼。

ansi:

unicode:fe 25 4e,其中ff fe表明是小頭方式儲存,真正的編碼是4e25

unicode big endian:

utf-8:ef bb bf e4 b8 a5,前三個位元組ef bb bf表示這是utf-8編碼,後三個e4b8a5就是的具體編碼,它的儲存順序與編碼順序是一致的。

例如:chen25陳 的utf-8編碼為

同樣以ef bb bf開頭

資料: 

判斷作業系統的位數和主機位元組序s

實現了2個 函式,判斷作業系統的位數和主機位元組序 include intshow sys bit void intshow sys endian void intmain intargc,char argv 獲取作業系統的位數 返回的為實際位數 intshow sys bit void 獲取主機位...

作業系統 位元組序中的大端序和小端序的區別

先上結論 咱們預設人讀位元組時 從右往左讀 這就是小端序 因為計算機處理的時候會從低位到高位處理 和人的習慣正好相反 位元組序,又稱端序或尾序 英語中用單詞 endianness 在幾乎所有的平台上,多位元組物件都被儲存為連續的位元組序列。例如在 go 語言中,乙個型別為int的變數x位址為0x10...

網路程式設計中的網路位元組序與主機位元組序

一 主機位元組序 不同的cpu有不同的位元組序型別 這些位元組序是指整數在記憶體中儲存的順序 這個叫做主機序 最常見的有兩種 例子 在記憶體中雙字0x01020304 dword 的儲存方式 記憶體位址 4000 4001 4002 4003 le 04 03 02 01 be 01 02 03 0...