htons(), ntohl(), ntohs(),htons()这4个函数

htons(), ntohl(), ntohs(),htons()这4个函数在 C C 写网络程序的时候 往往会遇到字节的网络顺序和主机顺序的问题 这是就可能用到 htons ntohl ntohs htons 这 4 个函数 网络字节顺序与本地字节顺序之间的转换函数 htonl HosttoNetwor ntohl NetworktoHos htons HosttoNetwor

在Linux系统下:htonl(),htons(), ntohl(), ntohs()的头文件及函数定义:  
  #include

 

  uint32_t htonl(uint32_t hostlong);   

  uint16_t htons(uint16_t hostshort);   
  uint32_t ntohl(uint32_t netlong);   
  uint16_t ntohs(uint16_t netshort); 

  在windows系统下:htonl(),htons(), ntohl(), ntohs(), inet_addr()使用说明  
  ntohs()   简述: 

  将一个无符号短整形数从网络字节顺序转换为主机字节顺序。  
  #include

 

  u_short PASCAL FAR ntohs( u_short netshort);   

  netshort:一个以网络字节顺序表达的16位数。   注释: 

  本函数将一个16位数由网络字节顺序转换为主机字节顺序。   
  返回值:ntohs()返回一个以主机字节顺序表达的数。  


 ntohl()   简述: 

  将一个无符号长整形数从网络字节顺序转换为主机字节顺序。   
#include

 

 u_long PASCAL FAR ntohl( u_long netlong);



 netlong:一个以网络字节顺序表达的32位数。  
 注释: 

  本函数将一个32位数由网络字节顺序转换为主机字节顺序。   
返回值: 

  ntohl()返回一个以主机字节顺序表达的数。   


htons()   简述: 

  将主机的无符号短整形数转换成网络字节顺序。
//将无符号短整型主机字节序转换为网络字节序 

  #include

 

  u_short PASCAL FAR htons( u_short hostshort);   


  hostshort:主机字节顺序表达的16位数。   
  注释: 

  本函数将一个16位数从主机字节顺序转换成网络字节顺序。 
  返回值: 

  htons()返回一个网络字节顺序的值。 
  简单地说,htons()就是将一个数的高低位互换   (如:12 34 –> 34 12)  

  VB表示: 

  MsgBox Hex(htons(&H1234))   显示值为 3412  


  htonl() 

  简述: 
  将主机的无符号长整形数转换成网络字节顺序。

   //将无符号长整型网络字节序转换为主机字节序 

  #include

 

  u_long PASCAL FAR htonl( u_long hostlong); 
  hostlong:主机字节顺序表达的32位数。 



  注释: 

  本函数将一个32位数从主机字节顺序转换成网络字节顺序。   
  返回值: 

  htonl()返回一个网络字节顺序的值。   
  
  inet_addr()   简述: 

  将一个点间隔地址转换成一个in_addr。   
  #include

 

  unsigned long PASCAL FAR inet_addr( const struct FAR* cp); 
  cp:一个以Internet标准“.”间隔的字符串。


  例如202.38.214.xx   当IP地址为255.255.255.255是被认为无效IP地址。 

  本函数解释cp参数中的字符串,这个字符串用Internet的“.”间隔格式表示一个数字的Internet地址。   
  返回值: 

  一个无符号长整形数,可用作Internet地址。所有Internet地址以网络字节顺序返回(字节从左到右排列)。




  inet_ntoa()   简述: 

  将网络地址转换成“.”点隔的字符串格式。   
#include

 

char FAR* PASCAL FAR inet_ntoa( struct in_addr in); 





in:一个表示Internet主机地址的结构。  
 注释: 

  本函数将一个用in参数所表示的Internet地址结构转换成以“.” 间隔的诸如“a.b.c.d”的字符串形式。请注意inet_ntoa()返回的字符串存放在WINDOWS套接口实现所分配的内存中。应用程序不应假设该内存是如何分配的。在同一个线程的下一个WINDOWS套接口调用前,数据将保证是有效。 
  当IP地址为255.255.255.255是认为有效IP地址。这是与inet_addr()的区别   

 返回值: 

  若无错误发生,inet_ntoa()返回一个字符指针。否则的话,返回NULL。其中的数据应在下一个WINDOWS套接口调用前复制出来。  
  i
net_aton()   与inet_ntoa()作用相反。   


inet_pton()   简述: 

  本函数将点分十进制转换为整数   
#include

  
#include

  
#include


int inet_pton(int af, const char *src, void *dst); 
  这个函数转换字符串到网络地址,第一个参数af是地址族,转换后存在dst中   inet_pton 是inet_addr的扩展,支持的多地址族有下列:   af = AF_INET 
  src为指向字符型的地址,即ASCII的地址的首地址(ddd.ddd.ddd.ddd格式的),函数将该地址 
  转换为in_addr的结构体,并复制在*dst中   af =AF_INET6 
  src为指向IPV6的地址,,函数将该地址转换为in6_addr的结构体,并复制在*dst中   如果函数出错将返回一个负值,并将errno设置为EAFNOSUPPORT,如果参数af指定的地址族和src格式不对,函数将返回0。   







#include

  
#include

  
#include

 

const char *inet_ntop(int af, const void *src, char *dst, socklen_t cnt); 
  这个函数转换网络二进制结构到ASCII类型的地址,参数的作用和上面相同,只是多了一个参数socklen_t cnt,他是所 
  指向缓存区dst的大小,避免溢出,如果缓存区太小无法存储地址的值,则返回一个空指针,并将errno置为ENOSPC   





atoi() 

  array to integer将字符串转换为整形数 首先,假设你已经有了一个sockaddr_in结构体ina,你有一个IP地址”132.241.5.10″ 要储存在其中,你就要用到函数inet_addr(),将IP地址从 点数格式转换成无符号长整型。   使用方法如下: 
  ina.sin_addr.s_addr = inet_addr(“132.241.5.10”); 
  注意,inet_addr()返回的地址已经是网络字节格式,所以你无需再调用 函数htonl()。   我们现在发现上面的代码片断不是十分完整的,因为它没有错误检查。 显而易见,当inet_addr()发生错误时返回-1。记住这些二进制数字?(无符 号数)-1仅仅和IP地址255.255.255.255相符合!这可是广播地址!大错特 错!记住要先进行错误检查。 
  好了,现在你可以将IP地址转换成长整型了。有没有其相反的方法呢? 它可以将一个in_addr结构体输出成点数格式? 这样的话,你就要用到函数 inet_ntoa()(“ntoa”的含义是”network to ascii”),就像这样: 
  printf(“%s”,inet_ntoa(ina.sin_addr)); 
  它将输出IP地址。需要注意的是inet_ntoa()将结构体in-addr作为一 个参数,不是长整形。同样需要注意的是它返回的是一个指向一个字符的 指针。它是一个由inet_ntoa()控制的静态的固定的指针,所以每次调用 inet_ntoa(),它就将覆盖上次调用时所得的IP地址。例如: 
  char *a1, *a2;   a1 = inet_ntoa(ina1.sin_addr); /* 这是198.92.129.1 */   a2 = inet_ntoa(ina2.sin_addr); /* 这是132.241.5.10 */   printf(“address 1: %s “,a1);   printf(“address 2: %s “,a2);   输出如下: 
  address 1: 132.241.5.10   
address 2: 132.241.5.10 
  假如你需要保存这个IP地址,使用strcopy()函数来指向你自己的字符指针。   
*   测试代码如下   










#include  
 #include   
#include  
 #include  
 #include 

  int main(int argc, char* argv[])   { 
  struct in_addr addr1,addr2;   

   ulong   l1,l2; 

   l1= inet_addr(“192.168.0.74”);   l2 = inet_addr(“211.100.21.179”);  
   memcpy(&addr1, &l1, 4); 
   memcpy(&addr2, &l2, 4); 

   printf(“%s : %s “, inet_ntoa(addr1), inet_ntoa(addr2));    //注意这一句的运行结果  
   printf(“%s “, inet_ntoa(addr1));

printf(“%s “, inet_ntoa(addr2)); 

 

 

return 0; 

 

 

 

 

实际运行结果如下:

 

 

 

192.168.0.74 : 192.168.0.74 

 

 

 

 

 

 

//

从这里可以看出

,printf

里的

inet_ntoa

只运行了一次。

 

 

 

192.168.0.74 

 

 

211.100.21.179 

 

 

inet_ntoa

返回一个

char 

*,

而这个

char 

*

的空间是在

inet_ntoa

里面静态分配的,所以

inet_ntoa

后面的调用会覆盖上一次的调用。

新濠天地娱乐场

66bb.org 

第一句

printf

的结果

只能说明在

printf

里面的可变参数的求值是从右到左的,仅此而已。

printf(“%s “, inet_ntoa(addr2)); 

 

 

return 0; 

 

 

 

 

实际运行结果如下:

 

 

 

192.168.0.74 : 192.168.0.74 

 

 

 

 

 

 

//

从这里可以看出

,printf

里的

inet_ntoa

只运行了一次。

 

 

 

192.168.0.74 

 

 

211.100.21.179 

 

 

inet_ntoa

返回一个

char 

*,

而这个

char 

*

的空间是在

inet_ntoa

里面静态分配的,所以

inet_ntoa

后面的调用会覆盖上一次的调用。

新濠天地娱乐场

66bb.org 

第一句

printf

的结果

只能说明在

printf

里面的可变参数的求值是从右到左的,仅此而已。

  printf(“%s “, inet_ntoa(addr2));   return 0;   } 

  实际运行结果如下: 
  192.168.0.74 : 192.168.0.74       //从这里可以看出,printf里的inet_ntoa只运行了一次。   

 192.168.0.74   211.100.21.179 

  inet_ntoa返回一个char *,而这个char *的空间是在inet_ntoa里面静态分配的,所以inet_ntoa后面的调用会覆盖上一次的调用。第一句printf的结果只能说明在printf里面的可变参数的求值是从右到左的,仅此而已。


printf(“%s “, inet_ntoa(addr2)); 

 

 

return 0; 

 

 

 

 

实际运行结果如下:

 

 

 

192.168.0.74 : 192.168.0.74 

 

 

 

 

 

 

//

从这里可以看出

,printf

里的

inet_ntoa

只运行了一次。

 

 

 

192.168.0.74 

 

 

211.100.21.179 

 

 

inet_ntoa

返回一个

char 

*,

而这个

char 

*

的空间是在

inet_ntoa

里面静态分配的,所以

inet_ntoa

后面的调用会覆盖上一次的调用。

新濠天地娱乐场

66bb.org 

第一句

printf

的结果

只能说明在

printf

里面的可变参数的求值是从右到左的,仅此而已。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/217216.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 上午10:05
下一篇 2026年3月18日 上午10:05


相关推荐

  • Fiddler安装教程(图文版)「建议收藏」

    Fiddler安装教程(图文版)「建议收藏」本章教程,主要介绍如何在windows10系统上安装Fiddler。一、Fiddler软件简介二、软件官网地址三、图文下载步骤四、软件安装步骤五、结语一、Fiddler软件简介Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的“进出”Fiddler的数据(指cookie,html,js,css等文件)。Fiddler要比其他的网络调试器要更加简单,因为它不仅仅暴露http通讯还提供了一个用户友好…

    2025年8月22日
    6
  • “ORA-01017(:用户名/口令无效; 登录被拒绝)”解决办法「建议收藏」

    “ORA-01017(:用户名/口令无效; 登录被拒绝)”解决办法「建议收藏」报错:ORA-01017(:用户名/口令无效;登录被拒绝)1.打开CMD命令窗,输入sqlplus/assysdba1)修改密码SQL>alteruser用户名identifiedby密码2)用户被锁定,解锁ALTERUSERusernameACCOUNTUNLOCK;再次登录验证,成功…

    2022年6月1日
    232
  • web前端常见面试题总结

    web前端常见面试题总结人生的路上少不了尝试,人人都是打工人,但愿这份面试题可以帮助到你H5有哪些新特性?绘画canvas(随时随地绘制2D图形)、svg(描述XML中的2D图形)元素语义化标签header、ment、content、footer…新增的input类型和属性音频,视频H5地理定位H5拖放H5WebStorage存储H5应用程序缓存H5中的WebworkersH5服务器发送事件(server-sentevent)允许网页获得来自服务器的更新WebSocket在单个TCP连接上进

    2025年11月25日
    7
  • Elasticsearch学习,请先看这一篇!

    题记:Elasticsearch研究有一段时间了,现特将Elasticsearch相关核心知识、原理从初学者认知、学习的角度,从以下9个方面进行详细梳理。欢迎讨论……0.带着问题上路——ES是如何产生的?(1)思考:大规模数据如何检索?如:当系统数据量上了10亿、100亿条的时候,我们在做系统架构的时候通常会从以下角度去考虑问题:1)用什么数据库好?(mysql、sybase、oracle、达

    2022年4月8日
    33
  • 智谱 AI 的意外之举:CodeGeex 插件集成 Claude 模型

    智谱 AI 的意外之举:CodeGeex 插件集成 Claude 模型

    2026年3月12日
    3
  • css transition动画_css3过渡属性有几种

    css transition动画_css3过渡属性有几种css动画效果之transition(动画效果属性)

    2022年4月21日
    52

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号