ntohs和htons的区别

虽然注册CSDN已经有好几年了,学习写程序也有两年的时间了。对于绝大数人来说,我还是得菜鸟。平时遇到什么问题也会来到这个平台搜索别人的解答。也从这个平台上获益很多。

      今天在公司因为一个问题和同事就关于htons与ntohs有没有区别探讨了一下,因为我平时也没留意过,凭着我自己的理解,认为是没有区别的。比如,同在X86的机器下,这两个函数都不是把小端的内存表示方法转成大端的吗。在回来的路上,我想回来查查,同时也想到何不就这个问题写下来,方便自己以后查看,也帮助那些想要解决同样问题的同志呢,于是就开始了我第一篇技术贴。希望我自己也会一直这么继续下去。好了闲话少说,开始正题吧。

      我用vc试了一下,结果是相同的。

 

 

      我就想去看看linux的源代码(/include/netinet/in.h)

# if __BYTE_ORDER == __BIG_ENDIAN
/* The host byte order is the same as network byte order,
   so these functions are all just identity.  */
# define ntohl(x) (x)
# define ntohs(x) (x)
# define htonl(x) (x)
# define htons(x) (x)
# else
#  if __BYTE_ORDER == __LITTLE_ENDIAN
#   define ntohl(x) __bswap_32 (x)
#   define ntohs(x) __bswap_16 (x)
#   define htonl(x) __bswap_32 (x)
#   define htons(x) __bswap_16 (x)
#  endif
# endif


      代码是一样的。


      ps: 开始我以为htons是函数,在源码包找了两个小时都没有找到,在绝望的时候看了下头文件,我汗颜了。

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/kobeyxyx/archive/2010/05/17/5601830.aspx

 

      从上面的头文件内容可以看出,如果平台是大字序的(如Pocket PC),则这些函数不作任何转换,只有在平台是小字序时(如X86),这些函数才进行相应的转换,htons和ntohs(以及htonl和ntohl)实际上没有任何区别,都是把字节序反转,只在于使用者对网络端和主机端理解意义的不同。

 

      在PPC中则转换函数无效,若要进行转换可以自定义一个类似的函数,如下所示:

#define local_htons(x) ((unsigned short int)((((unsigned short int)(x) & 0x00ff)<<8)|/
                                            (((unsigned short int)(x) & 0xff00)>>8)))
    
#define local_htonl(x) ((unsigned long int)((((unsigned long int)(x) & 0x000000ff)<<24)|/
                                            (((unsigned long int)(x) & 0x0000ff00)<<8)|/
                                            (((unsigned long int)(x) & 0x00ff0000)>>8)|/
                                            (((unsigned long int)(x) & 0xff000000)>>24)))


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/ast_224/archive/2009/03/28/4032491.aspx

 

检测系统的字序:

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/woyaoying/archive/2009/07/09/4333434.aspx

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这几个函数都是用来进行网络字节序和主机字节序之间的转换的。 - `htonl` (Host TO Network Long):将一个 32 位的主机字节序整数转换为网络字节序整数。如果主机字节序是大端字节序,则不做任何改变;如果主机字节序是小端字节序,则将其转换为大端字节序。返回网络字节序整数。 ```c++ #include <arpa/inet.h> uint32_t htonl(uint32_t hostlong); ``` - `htons` (Host TO Network Short):将一个 16 位的主机字节序整数转换为网络字节序整数。如果主机字节序是大端字节序,则不做任何改变;如果主机字节序是小端字节序,则将其转换为大端字节序。返回网络字节序整数。 ```c++ #include <arpa/inet.h> uint16_t htons(uint16_t hostshort); ``` - `ntohl` (Network TO Host Long):将一个 32 位的网络字节序整数转换为主机字节序整数。如果当前主机字节序是大端字节序,则不做任何改变;如果当前主机字节序是小端字节序,则将其转换为小端字节序。返回主机字节序整数。 ```c++ #include <arpa/inet.h> uint32_t ntohl(uint32_t netlong); ``` - `ntohs` (Network TO Host Short):将一个 16 位的网络字节序整数转换为主机字节序整数。如果当前主机字节序是大端字节序,则不做任何改变;如果当前主机字节序是小端字节序,则将其转换为小端字节序。返回主机字节序整数。 ```c++ #include <arpa/inet.h> uint16_t ntohs(uint16_t netshort); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值