我有问题。我有需要将域名转换为IP的代码。为此,我使用函数getaddrinfo()。但是看来,当我调用另一个函数(AFTER GETADDRINFO())时,我的程序崩溃了(getaddrinfo返回错误并生成了细分错误)。我发现,问题出在调用getaddrinfo()之后调用inet_ntop()函数。但我不知道为什么会发生这种奇怪的行为... 这是我的代码:
#include<stdio.h> //scanf , printf
#include<string.h> //strtok
#include<stdlib.h> //realloc
#include<sys/socket.h> //socket
#include<netinet/in.h> //sockaddr_in
#include<arpa/inet.h> //getsockname
#include<netdb.h> //hostent
#include<unistd.h> //close
#include <getopt.h> //getopt
#define DEFAULT_SOCKET_PROTOCOL 0
#define SERVER_PORT 43
#define IPv4_MAX_LENGTH 16
#define IPv6_MAX_LENGTH 40
#define DOMAIN_NAME_MAX_LENGTH 254
#define MAX_ADDRES_COUNT 3
typedef struct argument{
char address[DOMAIN_NAME_MAX_LENGTH];
char IPv4[IPv4_MAX_LENGTH];
char IPv6[IPv6_MAX_LENGTH];
int address_family;
struct argument *next;
} Argument;
int addres_to_ip(char * hostname , char* ip);
int get_IP_addresses(Argument **args);
int main(int argc , char *argv[])
{
Argument *args = NULL;
args = malloc(sizeof(Argument));
strcpy(args->address, "google.com");
get_IP_addresses(&args);
return 0;
}
int get_IP_addresses(Argument **args){
char addrstr[DOMAIN_NAME_MAX_LENGTH];
char tmp_ip[DOMAIN_NAME_MAX_LENGTH];
strcpy(tmp_ip, (*args)->address);
struct addrinfo tmp_ai, *new_ai;
tmp_ai.ai_flags = AI_CANONNAME;
tmp_ai.ai_family = AF_INET;
tmp_ai.ai_socktype = SOCK_STREAM;
printf("a\n");
if(getaddrinfo (tmp_ip, NULL, &tmp_ai, &new_ai) != 0){
printf("CHYBA: gettaddrinfo()\n");
}
while (new_ai)
{
inet_ntop (AF_INET, new_ai->ai_addr->sa_data, addrstr, DOMAIN_NAME_MAX_LENGTH);
new_ai = new_ai->ai_next;
}
return 0;
}
如果删除
inet_ntop(AF_INET,new_ai-> ai_addr-> sa_data,addrstr,DOMAIN_NAME_MAX_LENGTH);
它不会产生段错误。但是为什么要给它呢? 请帮忙,谢谢!
(PS:我试图尽我所能简化代码。这就是为什么它不会产生任何有用结果的原因)
答案 0 :(得分:0)
…给段错误。但是为什么要给它呢?
db.getCollection("_someCollection").find();
返回错误,在这种情况下,您可能不依赖设置getaddrinfo(…, &new_ai)
。
返回错误的原因是您忘记初始化new_ai
。如果您在tmp_ai.ai_protocol
的定义中使用了初始化程序,则不会发生这种情况:
tmp_ai