小端法與大端法(MD5疑惑解1)

2022-09-16 04:18:12 字數 1371 閱讀 5158

記得,在編寫md5時,有個疑惑是關於將int、long int等移置字串中,它將變成反序。對此的了解是小端法與大端法的區別。

下面是所查的資料:

《unxi網路程式設計》定義:術語「小端」和「大端」表示多位元組值的哪一端(小端或大端)儲存在該值的起始位址。小端存在起始位址,即是小端位元組序;大端存在起始位址,即是大端位元組序。

也可以說: 

1.小端法(little-endian)就是低位位元組排放在記憶體的低位址端即該值的起始位址,高位位元組排放在記憶體的高位址端。 

2.大端法(big-endian)就是高位位元組排放在記憶體的低位址端即該值的起始位址,低位位元組排放在記憶體的高位址端。

舉個簡單的例子,對於整形0x12345678。它在大端法和小端法的系統內中,分別如圖1所示的方式存放。

網路位元組序

我們知道網路上的資料流是位元組流,對於乙個多位元組數值,在進行網路傳輸的時候,先傳遞哪個位元組?也就是說,當接收端收到第乙個位元組的時候,它是將這個位元組作為高位還是低位來處理呢? 

網路位元組序定義:收到的第乙個位元組被當作高位看待,這就要求傳送端傳送的第乙個位元組應當是高位。而在傳送端傳送資料時,傳送的第乙個位元組是該數字在記憶體中起始位址對應的位元組。可見多位元組數值在傳送前,在記憶體中數值應該以大端法存放。 

網路位元組序說是大端位元組序。 

比如我們經過網路傳送0x12345678這個整形,在80x86平台中,它是以小端法存放的,在傳送前需要使用系統提供的htonl將其轉換成大端法存放,如圖2所示。

位元組序測試程式 

不同cpu平台上位元組序通常也不一樣,下面寫個簡單的c程式,它可以測試不同平台上的位元組序。

1 #include

2 #include

3 int main()

4 在80x86cpu平台上,執行該程式得到如下結果: 

[0]:0x78 

[1]:0x56 

[2]:0x34 

[3]:0x12

[0]:0x12 

[1]:0x34 

[2]:0x56 

[3]:0x78

分析結果,在80x86平台上,系統將多位元組中的低位儲存在變數起始位址,使用小端法。htonl將i_num轉換成網路位元組序,可見網路位元組序是大端法。

總結點:80x86使用小端法,網路位元組序使用大端法。

另註:linux 32(intel ia32)、windows(intel ia32)和linux 64(intel x86-64)是小端法;sun(執行solaris的sun microsystems sparc處理器)是大端法。 

大端法與小端法

一 什麼是位元組序 位元組序,顧名思義位元組的順序,再多說兩句就是大於乙個位元組型別的資料在記憶體中的存放順序 乙個位元組的資料當然就無需談順序的問題了 指的是記憶體的高 低位址,計算機在記憶體中存放資料的順序都是從低位址到高位址 高 低位元組 有些文章中稱低位位元組為最低有效位,高位位元組為最高有...

小端法 大端法

小端法little endian 諸如intel的機器就是採用這種規則 高位址存高位資料 大端法big endian 諸如ibm,motoral,sun採用此規則 低位址存高位資料 如需儲存oxeeaabbcc此數 如採用大端法儲存如下 address low high ee aa bb cc 如採...

大端法和小端法

在計算機記憶體中,通常是以位元組 byte 也就是 8 個位 bit 為基本儲存單元 也有以 16 位為基本儲存單元的 對於跨越多個位元組的資料型別 比如 int 長 4 個位元組 如何在記憶體中對這些位元組進行排序有兩種常見的方法 大端法 big endian 和小端法 little endian...