C++ 在Valgrind中,libcurl c+的泄漏汇总仍然可以访问+;代码
libcurl中的以下函数保存文件并返回http状态代码。但是,当我使用valgrind运行此程序时,它报告0字节表示“肯定丢失”、“间接丢失”、“可能丢失”,但它报告47448字节表示“仍然可以访问”。我正在尝试解析“仍然可访问”字节 下面的代码中是否存在任何潜在的内存泄漏C++ 在Valgrind中,libcurl c+的泄漏汇总仍然可以访问+;代码,c++,curl,memory-leaks,valgrind,libcurl,C++,Curl,Memory Leaks,Valgrind,Libcurl,libcurl中的以下函数保存文件并返回http状态代码。但是,当我使用valgrind运行此程序时,它报告0字节表示“肯定丢失”、“间接丢失”、“可能丢失”,但它报告47448字节表示“仍然可以访问”。我正在尝试解析“仍然可访问”字节 下面的代码中是否存在任何潜在的内存泄漏 size_t write_data(void *ptr, size_t size, size_t nmemb, FILE *stream){ size_t written = fwrite(ptr, size, n
size_t write_data(void *ptr, size_t size, size_t nmemb, FILE *stream){
size_t written = fwrite(ptr, size, nmemb, stream);
return written;
}
void connectAndSaveFile(char* url, char* output_file_name){
CURL *curl;
curl = curl_easy_init();
if (curl) {
FILE *fp = fopen(output_file_name,"wb");
curl_easy_setopt(curl, CURLOPT_URL, url);
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_data);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, fp);
curl_easy_perform(curl);
curl_easy_cleanup(curl);
fclose(fp);
}
}
string get_http_status_code(string URL) {
CURL *session;
session = curl_easy_init();
curl_easy_setopt(session, CURLOPT_URL, URL.c_str());
curl_easy_setopt(session, CURLOPT_NOBODY, true);
CURLcode curl_code = curl_easy_perform (session);
long http_code = 0;
curl_easy_getinfo (session, CURLINFO_RESPONSE_CODE, &http_code);
curl_easy_cleanup(session);
std::ostringstream buff;
buff << http_code;
return buff.str();
}
size\u t write\u数据(void*ptr、size\u t size、size\u t nmemb、FILE*stream){
写入的大小=写入(ptr、大小、nmemb、流);
书面回报;
}
void connectAndSaveFile(char*url,char*output\u file\u name){
卷曲*卷曲;
curl=curl_easy_init();
if(curl){
FILE*fp=fopen(输出文件名,“wb”);
curl_easy_setopt(curl,CURLOPT_URL,URL);
curl\u easy\u setopt(curl,CURLOPT\u WRITEFUNCTION,write\u data);
curl_easy_setopt(curl,CURLOPT_WRITEDATA,fp);
旋度,易于执行(旋度);
旋度\轻松\清洁(旋度);
fclose(fp);
}
}
字符串获取\u http\u状态\u代码(字符串URL){
第*届会议;
session=curl_easy_init();
curl_easy_setopt(session,CURLOPT_URL,URL.c_str());
curl_easy_setopt(会话,CURLOPT_NOBODY,true);
CURLcode curl\u code=curl\u easy\u perform(会话);
长http_代码=0;
curl\u easy\u getinfo(会话、CURLINFO\u响应代码和http\u代码);
旋涡轻松清理(课时);
std::ostringstream buff;
buff上面提到的大部分代码都是使用的。因此我认为我们必须查看文档,阅读API以及推荐的步骤
然而,在下面的方法中,客户端正在传递API正在写入的指针,并返回给调用者。一旦使用完成,需要在客户端(调用此函数的人)代码中释放此内存
size_t write_data(void *ptr, size_t size, size_t nmemb, FILE *stream)
但是,在纯C++方式中,我们应该使用 STD::FStrand;STD::String ,这样我们就不必担心内存管理。
“仍然可以到达”通常不是真正的泄漏
如果使用和,您可能会获得更少的可访问内存
他的写回调没有分配任何内容,它只是将数据写入libcurl传递给它的文件中。。。