_res_9_getservers _res_9_ninit _res_9_ndestroy 报错

在我们添加开放平台时可能会报错误信息

Undefined symbols for architecture x86_64:
“_res_9_getservers”, referenced from:
+[TXRtmpApi getDNSServers] in TXRTMPSDK(TXRTMPAPI.o)
“_res_9_ninit”, referenced from:
+[TXRtmpApi getDNSServers] in TXRTMPSDK(TXRTMPAPI.o)
“_res_9_ndestroy”, referenced from:
+[TXRtmpApi getDNSServers] in TXRTMPSDK(TXRTMPAPI.o)
ld: symbol(s) not found for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)

如图所示

这里写图片描述

添加依赖库libresolv.tbd即可

`curl_global_init`和`curl_easy_init`都是libcurl库中的初始化函数,但是它们的作用不同。 `curl_global_init`用于初始化libcurl库的全局环境,包括SSL、Winsock等。它只需要在程序运行时调用一次。如果在多线程中使用libcurl库,应该在每个线程中调用`curl_global_init`函数来初始化全局环境。如果没有调用`curl_global_init`,则在使用libcurl库时会自动调用它进行初始化。 `curl_easy_init`用于初始化一个CURL句柄,CURL句柄用于执行HTTP请求和处理响应。每个HTTP请求需要创建一个CURL句柄,当HTTP请求完成后,需要使用`curl_easy_cleanup`函数清理CURL句柄。 在使用libcurl库时,应该先调用`curl_global_init`函数初始化全局环境,然后在需要执行HTTP请求时,使用`curl_easy_init`函数初始化一个CURL句柄。在HTTP请求完成后,使用`curl_easy_cleanup`函数清理CURL句柄,并在程序结束时调用`curl_global_cleanup`函数释放所有全局资源。 以下是一个示例,用于初始化libcurl库的全局环境并执行HTTP请求: ```c #include <stdio.h> #include <curl/curl.h> int main(void) { CURL *curl; CURLcode res; curl_global_init(CURL_GLOBAL_DEFAULT); // 初始化全局环境 curl = curl_easy_init(); // 初始化CURL句柄 if (curl) { curl_easy_setopt(curl, CURLOPT_URL, "https://example.com"); res = curl_easy_perform(curl); // 执行HTTP请求 if (res != CURLE_OK) { fprintf(stderr, "curl_easy_perform() failed: %s\n", curl_easy_strerror(res)); } curl_easy_cleanup(curl); // 清理CURL句柄 } curl_global_cleanup(); // 释放全局资源 return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值