inet_ntoa函数的问题- 网络编程

转自:http://blog.ednchina.com/yqally/1969057/message.aspx

 简述:

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

  #include <winsock.h>

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

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

  注释:

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

  返回值:

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

  测试代码如下  

 #include <stdio.h>

  #include <sys/socket.h>

  #include <netinet/in.h>

  #include <arpa/inet.h>

  #include <string.h>

  int main(int aargc, 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里面的可变参数的求值是从右到左的,仅此而已。

  参见:

  inet_addr().

你可能感兴趣的:(网络编程)