《UNXI網絡編程》定義:術語「小端」和「大端」表示多字節值的哪一端(小端或大端)存儲在該值的起始地址。小端存在起始地址,便是小端字節序;大端存在起始地址,便是大端字節序。編程
也能夠說:
1.小端法(Little-Endian)就是低位字節排放在內存的低地址端即該值的起始地址,高位字節排放在內存的高地址端。
2.大端法(Big-Endian)就是高位字節排放在內存的低地址端即該值的起始地址,低位字節排放在內存的高地址端。網絡
舉個簡單的例子,對於整形0x12345678。它在大端法和小端法的系統內中,分別如圖1所示的方式存放。測試
咱們知道網絡上的數據流是字節流,對於一個多字節數值,在進行網絡傳輸的時候,先傳遞哪一個字節?也就是說,當接收端收到第一個字節的時候,它是將這個字節做爲高位仍是低位來處理呢?
網絡字節序定義:收到的第一個字節被看成高位看待,這就要求發送端發送的第一個字節應當是高位。而在發送端發送數據時,發送的第一個字節是該數字在內存中起始地址對應的字節。可見多字節數值在發送前,在內存中數值應該以大端法存放。
因此說網絡字節序是大端字節序。
好比咱們通過網絡發送0x12345678這個整形,在intel平臺中,它是以小端法存放的,在發送前須要使用系統提供的htonl將其轉換成大端法存放,如圖2所示。spa
字節序測試代碼:code
1 #include<stdio.h> 2 #include<netinet/in.h> 3 int main(){ 4 int host_num=0x12345678; 5 printf("host byte order:\n"); 6 printf("0:0x%x\n",*((char*)&host_num+0)); 7 printf("1:0x%x\n",*((char*)&host_num+1)); 8 printf("2:0x%x\n",*((char*)&host_num+2)); 9 printf("3:0x%x\n",*((char*)&host_num+3)); 10 printf("net byte order:\n"); 11 int net_num=htonl(host_num); 12 printf("0:0x%x\n",*((char*)&net_num+0)); 13 printf("1:0x%x\n",*((char*)&net_num+1)); 14 printf("2:0x%x\n",*((char*)&net_num+2)); 15 printf("3:0x%x\n",*((char*)&net_num+3)); 16 return 0; 17 }
在intel平臺測試結果:blog
host byte order:
0:0x78
1:0x56
2:0x34
3:0x12
net byte order:
0:0x12
1:0x34
2:0x56
3:0x78內存
因此說intel平臺的主機字節序使用的是小端模式,網絡字節序使用的是大端模式。 網絡編程
以上部分來自網絡。it