socket 编程下 inet_ntoa() 函数的使用与注意事项

函数声明:char *inet_ntoa (struct in_addr);
  返回点分十进制的字符串在静态内存中的指针。
  所在头文件:<arpa/inet.h>
  //end linux 下
   函数功能:将网络地址转换成“.”点隔的字符串格式

        现在我们很幸运,因为我们有很多的函数来方便地操作 IP 地址。没有必要用手工计算它们,也没有必要用"<<"操作来储存成长整字型。首先,假设你已经有了一个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()。

 

我们如何输出一个点分十进制的IP呢?我们来看看下面的程序:

#include <stdio.h> 
  #include <sys/socket.h> 
  #include <netinet/in.h> 
  #include <arpa/inet.h> 
  #include <string.h> 
  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\n", inet_ntoa(addr1), inet_ntoa(addr2)); //注意这一句的运行结果 
  printf("%s\n", inet_ntoa(addr1)); 
  printf("%s\n", 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里面的可变参数的 求值是从右到左的,仅此而已。
————————————————
版权声明:本文为CSDN博主「暗剑」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/a4150902/article/details/7419995
————————————————
 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值