htonl()函数详解

在《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));

}

这样就能够保证数据的正确性。

 

posted on 2017-05-07 16:13  魄灠  阅读(6114)  评论(0编辑  收藏  举报