linux网络编程一:主机字节序与网络字节序的的判断
生活随笔
收集整理的這篇文章主要介紹了
linux网络编程一:主机字节序与网络字节序的的判断
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
?linux網絡編程一:主機字節序與網絡字節序的的判斷(1)現代CPU的累加器一次能裝載至少4字節(32位),即一個整數。那么這4字節在內存中排列的順序將影響它被累加器裝載成的整數值,這就是字節序問題。(2)字節序分大端字節序(big endian)和小端字節序(little endian),大端字字節序是指一個整數的高位字節(23~31bit)存儲在內存的低地址外,低位字節(0~7bit)存儲在內存的高地址處。 小端字節序則是指整數的高位字節存儲在內存的高地址處,而低位字節存儲在內存的低地址處。(3)現代PC大多采用小端字節序,因此小端字節序又被稱為主機字節序。(4)當格化數的數據在兩臺使用不同字節序的主機之間直接傳遞時,接收端必然錯誤解釋之。解決方法是:發送端總是把要發送的數據轉化成大端字節序數據后再發送,而接收端知道對方傳送過來的數據總是采用大端字節序,所以接收端可以根據自身采用的字節序決定是否對接收到的數據時行轉換。
(5)因此,大端字節序也稱為網絡字節序,它給所有接收數據的主機提供了一個正確解釋收到的格式化數據的保證。
#include <stdio.h> void byteorder() { union { short value; char union_bytes[ sizeof( short ) ]; } test; test.value = 0x0102; if ( ( test.union_bytes[ 0 ] == 1 ) && ( test.union_bytes[ 1 ] == 2 ) ) { printf( "big endian\n" ); } else if ( ( test.union_bytes[ 0 ] == 2 ) && ( test.union_bytes[ 1 ] == 1 ) ) { printf( "little endian\n" ); } else { printf( "unknown...\n" ); } } int main(int argc, char **argv) { byteorder(); return 0; }
總結
以上是生活随笔為你收集整理的linux网络编程一:主机字节序与网络字节序的的判断的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux下TCP通信简单实例
- 下一篇: linux网络编程二:基础socket,