簡體   English   中英

Valcurnd中仍然可以獲得libcurl C ++代碼的泄漏摘要

[英]Still reachable leak summary in Valgrind for libcurl c++ code

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();
}
  1. “仍然可以到達”通常不是泄漏

  2. 如果使用curl_global_initcurl_global_cleanup,則可能會獲得較少的內存。

上面提到的大多數代碼都使用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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM