htonl()函數詳解
阿新 • • 發佈:2017-05-07
理解 問題 自定義 大端 編譯器 正常 lin 代碼 ret
在《Linux網絡編程》這本書中提到htonl()函數的原型。實現代碼如下:
long htonl(long value)
{
return ((value <<24 )|((value<<8)&0x00FF0000)|((value>>8)&0x0000FF00)|(value>>24));
}
函數其實很好理解,就是小端裝換成大端,因為網絡地址是大端,而正常的網絡地址是小端。原理很好理解,一個四個值分別為:(假設value值為0x12345678,轉化後數據為:0x78563412)
1. value <<24 得到0x7800 0000
2.(value<<8)&0x00FF0000) 得到0x0056 0000
3.(value>>8)&0x0000FF00) 得到0x0000 3400
4.value>>24 得到0x0000 0012
這就是原理。
但是問題在於value <<24 和value>>24能否想要的值。
在windows的編譯器上,能夠成功的得到。
但是在Linux上得到的值是錯誤的,因為value<<24得到的值並非0x7800 0000 而是0x7812 3456
這就與想要的數據相勃。
保險起見使用一下自定義函數:
long htonl(long value)
{
return (((value <<24 )&0xFF000000)|((value<<8)&0x00FF0000)|((value>>8)&0x0000FF00)|((value>>24)&0x000000FF));
}
這樣就能夠保證數據的正確性。
htonl()函數詳解