我得到了以下代码的分段故障。
我需要程序做的是,当输入一个无效的/未知的名称或服务作为参数时,它只显示该特定服务的错误,并继续在提供的其余服务上工作。
现在,如果我在服务行中的任何位置包含无效服务(例如/dnslookup www.nhawurha.com www.google.com或www.google.com www.nhawurha.com),程序就可以工作。
但是,如果只将无效的服务用作唯一的参数(例如/dnslookup www.nhawurha.com),那么在打印错误后,它会给我一个分割错误。
任何形式的帮助都将不胜感激,谢谢!
#include <arpa/inet.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <netdb.h>
#define BUFLEN 1500
int main(int argc, char *argv[]) {
struct addrinfo hints, *ai, *result;
char ipaddrv4[BUFLEN];
char ipaddrv6[BUFLEN];
int error;
if (argc < 2) {
fprintf(stderr, "Missing <hostname> after %s \n", argv[0]);
return 0;
}
for (int j = 1; j < argc; j++) {
memset(&hints, 0, sizeof(hints));
hints.ai_family = PF_UNSPEC; /* IPv4, IPv6, or anything */
hints.ai_socktype = SOCK_DGRAM; /* Dummy socket type */
error = getaddrinfo(argv[j], NULL, &hints, &result);
if (error) {
fprintf(stderr, "ERROR (%s: %s)\n", argv[j], gai_strerror(error));
continue;
}
for (ai = result; ai != NULL; ai = ai->ai_next) {
if (ai->ai_family == AF_INET) {
struct sockaddr_in *ipv4 = (struct sockaddr_in *) ai->ai_addr;
void *addr = &(ipv4->sin_addr);
inet_ntop(AF_INET, addr, ipaddrv4, BUFLEN);
printf("%s IPv4 %s\n", argv[j], ipaddrv4);
}
else if (ai->ai_family == AF_INET6) {
struct sockaddr_in6 *ipv6 = (struct sockaddr_in6 *) ai->ai_addr;
void *addr = &(ipv6->sin6_addr);
inet_ntop(AF_INET6, addr, ipaddrv6, BUFLEN);
printf("%s IPv6 %s\n", argv[j], ipaddrv6);
}
else {
continue;
}
}
}
freeaddrinfo(result);
return 0;}
发布于 2019-02-12 16:45:34
看看' result‘参数--如果你唯一的查找失败,result将会被取消初始化,freeaddrinfo将会出现segfault错误。首先尝试将其初始化为NULL。
如果您有多个查找,那么还有第二个问题--内存泄漏,因为您没有对每个结果调用freeaddrinfo。
所以我认为你的逻辑应该更像这样:
for each command line arg
if lookup succeeds
print result
free result
else
print error请参阅适用于getaddrinfo的man page
https://stackoverflow.com/questions/54645761
复制相似问题