码迷,mamicode.com
首页 > 其他好文 > 详细

htonl()函数详解

时间:2017-05-07 16:48:46      阅读:440      评论:0      收藏:0      [点我收藏+]

标签:编译   函数   地址   网络   实现   保险   lin   nbsp   原理   

在《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()函数详解

标签:编译   函数   地址   网络   实现   保险   lin   nbsp   原理   

原文地址:http://www.cnblogs.com/lanlianggui/p/6821135.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!