linux网络编程一:主机字节序与网络字节序的的判断
生活随笔
收集整理的這篇文章主要介紹了
linux网络编程一:主机字节序与网络字节序的的判断
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
?linux網(wǎng)絡(luò)編程一:主機字節(jié)序與網(wǎng)絡(luò)字節(jié)序的的判斷(1)現(xiàn)代CPU的累加器一次能裝載至少4字節(jié)(32位),即一個整數(shù)。那么這4字節(jié)在內(nèi)存中排列的順序?qū)⒂绊懰焕奂悠餮b載成的整數(shù)值,這就是字節(jié)序問題。(2)字節(jié)序分大端字節(jié)序(big endian)和小端字節(jié)序(little endian),大端字字節(jié)序是指一個整數(shù)的高位字節(jié)(23~31bit)存儲在內(nèi)存的低地址外,低位字節(jié)(0~7bit)存儲在內(nèi)存的高地址處。 小端字節(jié)序則是指整數(shù)的高位字節(jié)存儲在內(nèi)存的高地址處,而低位字節(jié)存儲在內(nèi)存的低地址處。(3)現(xiàn)代PC大多采用小端字節(jié)序,因此小端字節(jié)序又被稱為主機字節(jié)序。(4)當(dāng)格化數(shù)的數(shù)據(jù)在兩臺使用不同字節(jié)序的主機之間直接傳遞時,接收端必然錯誤解釋之。解決方法是:發(fā)送端總是把要發(fā)送的數(shù)據(jù)轉(zhuǎn)化成大端字節(jié)序數(shù)據(jù)后再發(fā)送,而接收端知道對方傳送過來的數(shù)據(jù)總是采用大端字節(jié)序,所以接收端可以根據(jù)自身采用的字節(jié)序決定是否對接收到的數(shù)據(jù)時行轉(zhuǎn)換。
(5)因此,大端字節(jié)序也稱為網(wǎng)絡(luò)字節(jié)序,它給所有接收數(shù)據(jù)的主機提供了一個正確解釋收到的格式化數(shù)據(jù)的保證。
#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; }
總結(jié)
以上是生活随笔為你收集整理的linux网络编程一:主机字节序与网络字节序的的判断的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux下TCP通信简单实例
- 下一篇: linux网络编程二:基础socket,