9
    #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);

セグメンテーション違反が発生します。

これの何が問題になっていますか?

4

3 に答える 3

21

inet_ntoaヘッダー<arpa/inet.h>で定義されている
必要が#includeあります。そうでない場合、エラーが発生します

于 2013-03-26T15:53:00.363 に答える
2

inet_ntoaポインタは必要ありませんが、値

 char* ipaddr; 
 ipaddr = inet_ntoa(((struct sockaddr_in)(ifr.ifr_addr))->sin_addr); 

sin_addrがポインタの場合は、逆参照する必要があります。

inet_ntoaNULLエラーが発生した場合はが返されるためprintf、NULLを試行すると、セグメンテーション違反が発生します。

情報についてはこちらを、manページについてはこちらをご覧ください。

于 2013-03-26T11:27:23.267 に答える
1

警告を表示したくない場合は、inet_ntoaの戻り値をキャストするだけです。

ipaddr = (char *) inet_ntoa(((struct sockaddr_in *)&(ifr.ifr_addr))->sin_addr);

セグメンテーション違反は、前の関数の一部がエラー(null値)を返し、それをチェックしなかったことが原因である可能性があります

同じコードが私のLinuxボックスで機能しました。

于 2013-03-26T11:46:29.043 に答える