gpt4 book ai didi

c - getaddrinfo() 中的段错误

转载 作者:太空宇宙 更新时间:2023-11-04 03:04:08 25 4
gpt4 key购买 nike

我在 getaddrinfo() 中遇到段错误。

这是堆栈跟踪。

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0xb7ff4b70 (LWP 26872)]
__res_vinit (statp=0xb7ff4df4, preinit=0) at res_init.c:176
176 res_init.c: No such file or directory.
in res_init.c
(gdb) bt
#0 __res_vinit (statp=0xb7ff4df4, preinit=0) at res_init.c:176
#1 0x0042fe95 in *__GI___res_ninit (statp=0xb7ff4df4) at res_init.c:142
#2 0x00430ea0 in *__GI___res_maybe_init (resp=0xb7ff4df4, preinit=0) at res_libc.c:122
#3 0x003f86f4 in gaih_inet (name=<value optimized out>, service=<value optimized out>, req=0xb7ff3df8, pai=0xb7ff3db4, naddrs=0xb7ff3da4)
at ../sysdeps/posix/getaddrinfo.c:690
#4 0x003faa65 in *__GI_getaddrinfo (name=0x8203a68 "api.shoutcast.com", service=0x810ae72 "http", hints=0xb7ff3df8, pai=0xb7ff3e24)
at ../sysdeps/posix/getaddrinfo.c:2160
#5 0x08050a87 in test_addrinfo () at /kkkk/myaddrinfo.c:33

函数test_addrinfo()的来源;

    #ifndef   NI_MAXHOST
#define NI_MAXHOST 1025
#endif

struct addrinfo hints =
{
.ai_flags = 0, /* Input flags. nothing special */
.ai_family = PF_UNSPEC,/* Protocol family for socket. any */
.ai_socktype = SOCK_STREAM, /* Socket type. take any (SOCK_RAW, SOCK_STREAM, SOCK_DGRAM) */
.ai_protocol = IPPROTO_TCP, /* Protocol for socket. take any (IPPROTO_TCP and IPPROTO_UDP) */
.ai_addrlen = 0, /* Length of socket address. always 0 */
.ai_addr = NULL, /* Socket address for socket. always NULL */
.ai_canonname = NULL, /* Canonical name for service. always NULL */
.ai_next = NULL, /* Pointer to next in list. always NULL */
};



int test_addrinfo(void)
{
struct addrinfo *result = NULL;
struct addrinfo *res;
int error;

/* resolve the domain name into a list of addresses */
error = getaddrinfo("api.shoutcast.com", "http", &hints, &result);
if (error != 0)
{
fprintf(stderr, "error in getaddrinfo: %s\n", gai_strerror(error));
return EXIT_FAILURE;
}

/* loop over all returned results and do inverse lookup */
for (res = result; res != NULL; res = res->ai_next)
{
char hostname[NI_MAXHOST] = "";

error = getnameinfo(res->ai_addr, res->ai_addrlen, hostname, NI_MAXHOST, NULL, 0, 0);
if (error != 0)
{
fprintf(stderr, "error in getnameinfo: %s\n", gai_strerror(error));
continue;
}
if (*hostname != '\0')
printf("hostname: %s\n", hostname);
}

freeaddrinfo(result);
return EXIT_SUCCESS;
}

在valgrind中运行后,得到如下日志

    ==00:00:00:07.590 7788==
==00:00:00:07.590 7788== Process terminating with default action of signal 11 (SIGSEGV)
==00:00:00:07.590 7788== Bad permissions for mapped region at address 0x4033BDC
==00:00:00:07.590 7788== at 0x4348C8A: __res_vinit (res_init.c:176)
==00:00:00:07.645 7788==

此函数 test_addrinfo() 由我的应用程序中的顶层调用。我在另一个只有一个 main() 的应用程序中测试了相同的功能。它在那个应用程序中工作。

我怀疑我没有使用正确的 gnulib 库或错误的编译标志。有什么线索或提示吗?

最佳答案

我发现了问题。由于函数 getaddrinfo() 使用 alloca() - 它动态分配内存但在堆栈上(而不是在堆上),因此出现堆栈溢出。这是一个非常危险的功能。

我尝试放置 -fstack-protector-all gcc 标志,但没有成功。

关于c - getaddrinfo() 中的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7818246/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com