#include <netdb.h>
#include <stdio.h>
#include <sys/socket.h>
int main(int argc, char **argv)
{
char *ptr = NULL;
struct hostent *hptr = NULL;
struct in_addr *hipaddr = NULL;
ptr = argv[1];
inet_aton(ptr,hipaddr);
hptr = gethostbyaddr(hipaddr, 4, AF_INET);
printf("official hostname:%s\n",hptr->h_name);
return 0;
}
运行结果表明:分段故障(核心转储)。 但我不知道如何使它发挥作用。所以我需要一些帮助...
我将代码更改为:
#include <netdb.h>
#include <stdio.h>
#include <sys/socket.h>
int main(int argc, char **argv)
{
char *ptr = NULL;
struct hostent *hptr = NULL;
struct in_addr hipaddr ;
ptr = argv[1];
inet_aton(ptr,&hipaddr);
hptr = gethostbyaddr(&hipaddr, sizeof(hipaddr), AF_INET);
printf("official hostname:%s\n",hptr->h_name);
return 0;
}
然后它有效!但为什么?
答案 0 :(得分:3)
在第一个版本中,您将空指针传递给inet_aton
。然后inet_aton
尝试写入该地址,这会导致段错误。
inet_aton(ptr,hipaddr);//hipaddr is NULL
调用in_addr
时,需要将指针传递给inet_aton
结构。这是你在第二版中做的。
struct in_addr hipaddr;
inet_aton(ptr, &hipaddr);&hipaddr is a pointer to struct in_addr