socket 编程下 inet_ntoa() 函数

来源:互联网 发布:腾讯软件管家 编辑:程序博客网 时间:2024/05/01 05:55
函数声明: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呢?我们来看看下面的程序:

   

[cpp] view plain copy
  1. #include <stdio.h>   
  2.   #include <sys/socket.h>   
  3.   #include <netinet/in.h>   
  4.   #include <arpa/inet.h>   
  5.   #include <string.h>   
  6.   int main(int argc, char *argv[])   
  7.   {   
  8.   struct in_addr addr1,addr2;   
  9.   ulong l1,l2;   
  10.   l1= inet_addr("192.168.0.74");   
  11.   l2 = inet_addr("211.100.21.179");   
  12.   memcpy(&addr1, &l1, 4);   
  13.   memcpy(&addr2, &l2, 4);   
  14.   printf("%s : %s\n", inet_ntoa(addr1), inet_ntoa(addr2)); //注意这一句的运行结果   
  15.   printf("%s\n", inet_ntoa(addr1));   
  16.   printf("%s\n", inet_ntoa(addr2));   
  17.   return 0;   
  18.   }   


 

  实际运行结果如下:
  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里面的可变参数的求值是从右到左的,仅此而已。
0 0
原创粉丝点击