大端小端 網路位元組序

2021-08-01 10:27:51 字數 1016 閱讀 8014

(0)背景:

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

(1)網路位元組序定義:

收到的第乙個位元組被當作高位看待,這就要求傳送端傳送的第乙個位元組應當是高位。

(2)網路位元組序為大端序列:

在傳送端傳送資料時,傳送的第乙個位元組是該數字在記憶體中起始位址對應的位元組。可見多位元組數值在傳送前,在記憶體中數值應該以大端法存放。 

htons():將16位無符號整數從本地位元組序轉換成網路位元組序;

htonl():將32位無符號整數從本地位元組序轉換成網路位元組序;

ntohs():將16位無符號整數從網路位元組序轉換成本地位元組序;

ntohl():將32位無符號整數從網路位元組序轉換成本地位元組序;

(3)舉例:

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

(4)大端序列與小端序列:

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

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

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

如下圖:

(5)位元組序測試函式:

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

#include

#include

int main()

網路位元組序 大端 小端

1.小端法 little endian 就是低位位元組排放在記憶體的低位址端 即該值的起始位址 高位位元組排放在記憶體的高位址端 2.大端法 big endian 就是高位位元組排放在記憶體的低位址端 即該值的起始位址 低位位元組排放在記憶體的高位址端 網路上傳輸的資料都是位元組流,對於乙個多位元組...

大端 小端 網路位元組序

2010 10 10 17 44 58 分類 c vc c 舉報 字型大小訂閱 一 大端 小端 大端 和 小端 表示多位元組值的哪一端儲存在該值的起始位址處 小端儲存在起始位址處,即是小端位元組序 大端儲存在起始位址處,即是大端位元組序 或者說 1.小端法 little endian 就是低位位元組...

大端 小端 網路位元組序

網路位元組序 network byte order 一般是指大端 big endian,對大部分網路傳輸協議而言 傳輸,大端小端的概念是面向多位元組資料型別的儲存方式定義的,小端就是低位在前,大端就是高位在前,其中 前 是指靠近記憶體低位址,儲存在硬碟上就是先寫那個位元組 1 首先大小端是面向多位元...