#include <stdio.h>
#include <string.h> /* for strncpy */
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/ioctl.h>
#include <netinet/in.h>
#include <net/if.h>
int
main()
{
int fd;
struct ifreq ifr;
fd = socket(AF_INET, SOCK_DGRAM, 0);
/* I want to get an IPv4 IP address */
ifr.ifr_addr.sa_family = AF_INET;
/* I want IP address attached to "eth0" */
strncpy(ifr.ifr_name, "eth0", IFNAMSIZ-1);
ioctl(fd, SIOCGIFADDR, &ifr);
close(fd);
/* display result */
char* ipaddr;
ipaddr = inet_ntoa(((struct sockaddr_in *)&(ifr.ifr_addr))->sin_addr);
printf("%s\n", ipaddr);
return 0;
}
这一行:
ipaddr = inet_ntoa(((struct sockaddr_in *)&(ifr.ifr_addr))->sin_addr);
我得到了
iptry.c: In function ‘main’:
iptry.c:31:9: warning: assignment makes pointer from integer without a cast [enabled by default]
和
printf("%s\n", ipaddr);
我得到了分段错误。
这有什么问题?
答案 0 :(得分:20)
inet_ntoa
在标题<arpa/inet.h>
中定义,
需要#include
,否则会出现错误
答案 1 :(得分:1)
inet_ntoa
不要求指针,而是值
char* ipaddr;
ipaddr = inet_ntoa(((struct sockaddr_in)(ifr.ifr_addr))->sin_addr);
如果sin_addr
是指针,则需要取消引用它。
inet_ntoa
将返回NULL
,因此尝试printf
NULL会导致分段错误......
答案 2 :(得分:1)
如果您不想看警告,只需转换inet_ntoa的返回值
ipaddr = (char *) inet_ntoa(((struct sockaddr_in *)&(ifr.ifr_addr))->sin_addr);
分段错误可能是因为某些先前的函数返回错误(空值)并且您没有检查它
相同的代码在我的Linux Box中有效。