Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/cplusplus/160.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 在Valgrind中,libcurl c+的泄漏汇总仍然可以访问+;代码_C++_Curl_Memory Leaks_Valgrind_Libcurl - Fatal编程技术网

C++ 在Valgrind中,libcurl c+的泄漏汇总仍然可以访问+;代码

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

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, 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传递给它的文件中。。。