在 C++ 中异步下载 HTTP URL
下载 HTTP URL 的好方法是什么(例如 http://0.0.0.0/foo.htm ) 在 Linux 上的 C++ 中?我非常喜欢异步的东西.我的程序将有一个事件循环,它重复启动多个(非常小的)下载并在它们完成时对其进行操作(通过轮询或以某种方式得到通知).我宁愿不必生成多个线程/进程来完成此操作.这不应该是必要的.
What's a good way to download HTTP URLs (e.g. such as http://0.0.0.0/foo.htm ) in C++ on Linux ? I strongly prefer something asynchronous. My program will have an event loop that repeatedly initiates multiple (very small) downloads and acts on them when they finish (either by polling or being notified somehow). I would rather not have to spawn multiple threads/processes to accomplish this. That shouldn't be necessary.
我应该研究像 libcurl 这样的库吗?我想我可以使用非阻塞 TCP 套接字和 select() 调用手动实现它,但这可能不太方便.
Should I look into libraries like libcurl? I suppose I could implement it manually with non-blocking TCP sockets and select() calls, but that would likely be less convenient.
推荐答案
Libcurl 是要走的路.请参阅 http://curlpp.org 了解 C++ 绑定和一组出色的教程.
Libcurl is the way to go. See http://curlpp.org for C++ bindings and an excellent set of tutorials.
相关文章