我有一个案例,我使用 libcurl 和 c++ 下载一个 240 MB 的文件,但需要 15 分钟才能完成。我已确保我的写入回调尽可能快。它只是写入一个足够大的内存缓冲区来容纳数据。当我使用curl命令从同一服务器下载相同的文件时,只需要不到一分钟的时间。当我使用浏览器下载文件时,也只需要不到一分钟的时间。我是否可能错误地使用了 libcurl?这是我的代码片段......
wxString postFields;
postFields += "package_name=" + packageName;
if( desiredVersion != 0 )
postFields += wxString::Format( "&package_version=v%d", desiredVersion );
curl_easy_reset( curlHandleEasy );
curl_slist_free_all( headers );
headers = nullptr;
headers = curl_slist_append( headers, "Content-Type: application/x-www-form-urlencoded" );
headers = curl_slist_append( headers, "Accept: application/x-zip-compressed" );
url = "http://" + packageServer + ":7000/package_download";
urlData = url.c_str();
binResponse = new BinaryResponse( packageSize );
curl_easy_setopt( curlHandleEasy, CURLOPT_HTTPHEADER, headers );
curl_easy_setopt( curlHandleEasy, CURLOPT_POSTFIELDS, postFieldsData );
curl_easy_setopt( curlHandleEasy, …Run Code Online (Sandbox Code Playgroud)