金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網游開發(108)
(rss)
3. Golang(20)
(rss)
4. Linux/Unix(30)
(rss)
5. 軟工與管理(44)
(rss)
6. Python(23)
(rss)
7. Erlang(18)
(rss)
8. Rust(16)
(rss)
9. 其它(77)
(rss)
隨筆檔案
(423)
2023年1月 (1)
2022年11月 (1)
2022年10月 (2)
2022年9月 (1)
2022年4月 (6)
2022年1月 (2)
2021年12月 (4)
2021年11月 (6)
2021年10月 (2)
2021年9月 (2)
2021年8月 (7)
2021年7月 (2)
2021年5月 (2)
2021年3月 (1)
2021年2月 (2)
2021年1月 (1)
2020年12月 (1)
2020年10月 (1)
2020年9月 (5)
2020年8月 (1)
2020年7月 (1)
2020年6月 (1)
2020年4月 (2)
2020年3月 (3)
2020年2月 (3)
2020年1月 (1)
2019年12月 (1)
2019年9月 (2)
2019年4月 (2)
2019年1月 (1)
2018年12月 (1)
2018年11月 (3)
2018年10月 (1)
2018年9月 (3)
2018年8月 (3)
2018年7月 (2)
2018年6月 (4)
2018年5月 (4)
2018年4月 (4)
2018年3月 (1)
2018年1月 (2)
2017年12月 (2)
2017年11月 (3)
2017年10月 (3)
2017年8月 (7)
2017年7月 (1)
2017年6月 (1)
2017年5月 (3)
2017年4月 (3)
2017年3月 (3)
2017年2月 (2)
2017年1月 (2)
2016年12月 (5)
2016年11月 (2)
2016年10月 (2)
2016年9月 (1)
2016年8月 (6)
2016年7月 (3)
2016年6月 (2)
2016年5月 (4)
2016年4月 (2)
2016年3月 (2)
2016年1月 (3)
2015年12月 (2)
2015年11月 (2)
2015年10月 (1)
2015年8月 (2)
2015年7月 (1)
2015年6月 (1)
2015年5月 (4)
2015年4月 (3)
2015年3月 (4)
2015年2月 (5)
2015年1月 (4)
2014年12月 (3)
2014年11月 (3)
2014年10月 (2)
2014年9月 (3)
2014年8月 (1)
2014年4月 (4)
2014年3月 (1)
2014年2月 (4)
2014年1月 (5)
2013年12月 (5)
2013年11月 (5)
2013年9月 (2)
2013年8月 (2)
2013年7月 (2)
2013年6月 (2)
2013年5月 (1)
2013年1月 (2)
2012年12月 (1)
2012年11月 (1)
2012年9月 (1)
2012年8月 (3)
2012年7月 (2)
2012年6月 (1)
2012年4月 (3)
2012年3月 (2)
2012年2月 (3)
2012年1月 (2)
2011年11月 (2)
2011年10月 (3)
2011年9月 (2)
2011年8月 (2)
2011年7月 (3)
2011年6月 (2)
2011年5月 (3)
2011年1月 (2)
2010年12月 (1)
2010年11月 (2)
2010年10月 (2)
2010年9月 (3)
2010年8月 (2)
2010年7月 (3)
2010年6月 (1)
2010年5月 (3)
2010年4月 (3)
2010年3月 (5)
2010年2月 (4)
2010年1月 (4)
2009年12月 (2)
2009年11月 (3)
2009年10月 (4)
2009年9月 (3)
2009年8月 (2)
2009年7月 (4)
2009年6月 (1)
2009年5月 (3)
2009年4月 (4)
2009年3月 (2)
2009年2月 (5)
2009年1月 (1)
2008年12月 (7)
2008年11月 (4)
2008年10月 (1)
2008年9月 (3)
2008年8月 (4)
2008年7月 (3)
2008年6月 (4)
2008年5月 (6)
2008年4月 (7)
2008年3月 (6)
2008年1月 (5)
2007年12月 (7)
2007年11月 (4)
2007年10月 (5)
2007年9月 (6)
2007年8月 (8)
2007年7月 (5)
相冊
公告照片
搜索
積分與排名
積分 - 653843
排名 - 25
最新評論
1.?re: boost::asio::spawn 將一統C++網絡庫
asio 成為C++首選網絡庫
--linda
2.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--金慶
3.?re: mingw編譯OrzNet
能發送一個mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
5.?re: log4cxx中文輸出錯誤補丁
評論內容較長,點擊標題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯誤(11016)
2.?SVN中邪惡的replace(10937)
3.?VS2005編譯libevent(10404)
4.?混音算法的學習與研究(10183)
5.?C調用lua腳本的效率測試(9002)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯誤(18)
4.?C++引用優于指針(17)
5.?ACE與ASIO之間關于Socket編程的比較(16)
使用完成端口HTTP下載的代碼
使用完成端口HTTP下載的代碼
(轉載請注明來源于金慶的專欄)
試運行asio的async_client例程時,發現CPU占用很高,
所以又寫了一個相同功能但直接調用完成端口API的代碼,
進行比較,發現同樣占用CPU。
與flashget比較,下載速度差不多,但flashget不占CPU。
將直接API調用代碼和利用asio的代碼都列在下面。
進行測試時,要將其中的參數定義改改,如SERVER參數。
并且要找個大文件下載才有明顯結果。
#include <iostream>
#include <winsock2.h>
// Modify these:
// "http://server.test.com/jinq/test.zip"
#define SERVER "server.test.com"
#define REQ_PATH "/jinq/test.zip"
const char * SVR_IP = "127.0.0.1";
int main(int argc, char* argv[])
{
// Init.
WSADATA wsd;
WSAStartup(MAKEWORD(2, 2), &wsd);
HANDLE hCp = CreateIoCompletionPort(
INVALID_HANDLE_VALUE, NULL, 0, 0);
SOCKET skt = WSASocket(AF_INET,
SOCK_STREAM, 0, NULL, 0, WSA_FLAG_OVERLAPPED);
assert(INVALID_SOCKET != skt);
// connect skt and request
SOCKADDR_IN addr;
addr.sin_family = PF_INET;
addr.sin_port = htons(80);
addr.sin_addr.s_addr = inet_addr(SVR_IP);
connect(skt, (SOCKADDR*)&addr, sizeof(addr));
const char * REQ =
"GET " REQ_PATH " HTTP/1.0\r\n"
"Host: " SERVER "\r\n"
"Accept: */*\r\n"
"Connection: close\r\n\r\n";
send(skt, REQ, strlen(REQ), 0);
// Associate skt to completion port.
const DWORD COMPLETION_KEY = 12345;
CreateIoCompletionPort((HANDLE)skt,
hCp, COMPLETION_KEY, 0);
WSABUF wsaBuf;
wsaBuf.len = 64 * 1024 - 1;
wsaBuf.buf = new char[64 * 1024];
DWORD dwReceived;
DWORD dwFlags = 0;
WSAOVERLAPPED overlapped;
// Start recv.
ZeroMemory(&overlapped, sizeof(overlapped));
WSARecv(skt, &wsaBuf, 1,
&dwReceived,
&dwFlags,
&overlapped,
NULL);
// Check the completion port in loop.
while (true)
{
DWORD dwTransferred;
LPOVERLAPPED lpOverlapped;
DWORD dwKey;
BOOL bRet = GetQueuedCompletionStatus(
hCp, &dwTransferred, &dwKey, &lpOverlapped, 1000);
if (!bRet) continue;
assert(COMPLETION_KEY == dwKey);
std::cout << "Transferred: " << dwTransferred << std::endl;
assert(dwTransferred <= wsaBuf.len);
wsaBuf.buf[50] = '\0';
std::cout << "Content: " << wsaBuf.buf << std::endl;
// next recv
ZeroMemory(&overlapped, sizeof(overlapped));
WSARecv(skt, &wsaBuf, 1,
&dwReceived,
&dwFlags,
&overlapped,
NULL);
}
return 0;
}
#include <iostream>
#include <istream>
#include <ostream>
#include <string>
#include <boost/asio.hpp>
#include <boost/bind.hpp>
const std::string SERVER("MyServer");
const std::string PATH("/jinq/test.zip");
using boost::asio::ip::tcp;
class client
{
public:
client(boost::asio::io_service& io_service,
const std::string& server, const std::string& path)
: socket_(io_service)
{
// Query server and try to connect.
tcp::resolver resolver(io_service);
tcp::resolver::query query(server, "http");
tcp::resolver::iterator endpoint_iterator = resolver.resolve(query);
tcp::resolver::iterator end;
// Try each endpoint until we successfully establish a connection.
boost::system::error_code error = boost::asio::error::host_not_found;
while (error && endpoint_iterator != end)
{
socket_.close();
socket_.connect(*endpoint_iterator++, error);
}
if (error)
throw boost::system::system_error(error);
// Send the request.
boost::asio::streambuf request;
std::ostream request_stream(&request);
request_stream << "GET " << path << " HTTP/1.0\r\n";
request_stream << "Host: " << server << "\r\n";
request_stream << "Accept: */*\r\n";
request_stream << "Connection: close\r\n\r\n";
boost::asio::write(socket_, request);
// start reading...
boost::asio::async_read(socket_, response_,
boost::asio::transfer_at_least(1),
boost::bind(&client::handle_read_content, this,
boost::asio::placeholders::error));
}
private:
void handle_read_content(const boost::system::error_code& err)
{
if (!err)
{
// Write all of the data that has been read so far.
// std::cout << &response_ << "\n";
std::cout << "Received: " << response_.size() << std::endl;
response_.consume(response_.size());
// Continue reading remaining data until EOF.
boost::asio::async_read(socket_, response_,
boost::asio::transfer_at_least(1),
boost::bind(&client::handle_read_content, this,
boost::asio::placeholders::error));
}
else if (err != boost::asio::error::eof)
{
std::cout << "Error: " << err << "\n";
}
}
tcp::socket socket_;
boost::asio::streambuf response_;
};
int main(int argc, char* argv[])
{
try
{
boost::asio::io_service io_service;
client c(io_service, SERVER, PATH);
io_service.run();
}
catch (std::exception& e)
{
std::cout << "Exception: " << e.what() << "\n";
}
return 0;
}
posted on 2007-12-24 16:25
金慶
閱讀(2322)
評論(4)
編輯
收藏
引用
所屬分類:
1. C/C++
評論
#
re: 使用完成端口HTTP下載的代碼
2009-04-17 11:36
vvvb
ASIO內部也使用了IOCP模式的通信機制,因此應該是相似的結果
回復
更多評論
#
re: 使用完成端口HTTP下載的代碼
2011-08-19 15:34
金慶
只要有一個包到達,完成端口就執行一次從緩沖里讀操作檢測執行,而通常應用,一個數據段會由很多包組成,這樣,內核線程需要調度很多次,而如果使用非阻塞 SOCKET讀,通過定時檢查機制,可以避免這種內部的頻繁調度. 參見: 網絡編程--走出完成端口的誤區 (
http://blog.csdn.net/danscort2000/article/details/4703391
)
回復
更多評論
#
re: 使用完成端口HTTP下載的代碼
2013-04-17 00:30
cmi
通過運行博主的iocp寫的下載代碼,下載一個300m的文件,速度150~300k/s
cpu的占用率為0~1,沒有出現樓主所說cpu占用率很高的情況。
博主還記得你的問題到底是什么原因引起的嗎?
我在考慮是否要用iocp寫,看了博主提供的這篇文章
http://blog.csdn.net/danscort2000/article/details/4703391
,很是糾結。
我感覺這篇文章說的并不正確。
回復
更多評論
#
re: 使用完成端口HTTP下載的代碼
2013-12-16 16:39
金慶
@cmi
需要內網測試,速度接近網絡帶寬。
回復
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
How are dtLinks created in NavMesh
C++ parameter passing rules
Naming Conventions for Accessors
Visual Studio 2019 Compiler Hangs
Fbx File Format Identifier
查找內存錯誤
std::thread 中的異常會丟失調用棧
用賦值代替 protobuf CopyFrom()
vs2017 linux 編譯輸出改成 vs 格式
為 LiteIDE 添加選中標記
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
日韩欧美亚洲综合久久影院Ds
|
性做久久久久久免费观看
|
色综合久久天天综合
|
色悠久久久久久久综合网
|
国产精品国色综合久久
|
亚洲综合精品香蕉久久网97
|
久久久久无码中
|
久久被窝电影亚洲爽爽爽
|
久久中文字幕无码专区
|
久久久久久人妻无码
|
欧美色综合久久久久久
|
国产美女久久精品香蕉69
|
久久99热这里只有精品国产
|
久久久精品人妻一区二区三区蜜桃
|
久久久久久久综合日本亚洲
|
久久无码专区国产精品发布
|
伊人久久综合热线大杳蕉下载
|
亚洲综合精品香蕉久久网
|
狠狠人妻久久久久久综合蜜桃
|
久久人做人爽一区二区三区
|
久久久久99精品成人片三人毛片
|
久久精品国产亚洲av高清漫画
|
18禁黄久久久AAA片
|
久久久久无码中
|
欧洲性大片xxxxx久久久
|
日本精品久久久中文字幕
|
99久久人妻无码精品系列
|
久久精品无码专区免费青青
|
99久久精品免费看国产一区二区三区
|
国产精品久久久久久搜索
|
亚洲国产精品久久电影欧美
|
欧美亚洲日本久久精品
|
久久久久九国产精品
|
久久亚洲中文字幕精品一区
|
久久伊人中文无码
|
人妻中文久久久久
|
久久久午夜精品福利内容
|
久久国产AVJUST麻豆
|
一本色综合网久久
|
99久久久国产精品免费无卡顿
|
伊人久久综合精品无码AV专区
|