对于libcurl c ++代码,Valgrind仍然可以访问泄漏摘要

时间:2014-09-10 01:01:03

标签: 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, 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();
}

2 个答案:

答案 0 :(得分:1)

  1. &#34;仍然可以访问&#34;最常见的不是泄漏

  2. 如果您使用curl_global_initcurl_global_cleanup

  3. ,您的内存可能会略微降低

答案 1 :(得分:0)

上面提到的大多数代码都使用libcurl。所以我认为我们必须查看文档并阅读API以及建议的步骤。

但是在下面的方法中,客户端正在传递fwrite API正在写入的指针并返回给调用者。一旦使用完成,需要在客户端(将调用此函数)代码中释放此内存。

size_t write_data(void *ptr, size_t size, size_t nmemb, FILE *stream)

然而,在纯C ++方式中,我们应该使用std::fstream & std::string,这样我们就不用担心内存管理了。有关更多信息,请参阅以下链接:

https://stackoverflow.com/a/22048298/2724703