金慶的專欄
C++博客
::
首頁
::
新隨筆
::
聯(lián)系
::
聚合
::
管理
::
423 隨筆 :: 0 文章 :: 454 評論 :: 0 Trackbacks
公告
我的隨筆
我的評論
我參與的隨筆
留言簿
(12)
給我留言
查看公開留言
查看私人留言
隨筆分類
(502)
1. C/C++(166)
(rss)
2. 網(wǎng)游開發(fā)(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)
相冊
公告照片
搜索
積分與排名
積分 - 653959
排名 - 25
最新評論
1.?re: boost::asio::spawn 將一統(tǒng)C++網(wǎng)絡(luò)庫
asio 成為C++首選網(wǎng)絡(luò)庫
--linda
2.?re: log4cxx中文輸出錯誤補丁
評論內(nèi)容較長,點擊標題查看
--金慶
3.?re: mingw編譯OrzNet
能發(fā)送一個mingw編譯好的OrzNet庫給我嗎? liuweiqcxy@163.com
謝謝!
--劉威
4.?re: log4cxx中文輸出錯誤補丁
評論內(nèi)容較長,點擊標題查看
--bigbad
5.?re: log4cxx中文輸出錯誤補丁
評論內(nèi)容較長,點擊標題查看
--bigbad
閱讀排行榜
1.?"multiple definition of" 錯誤(11016)
2.?SVN中邪惡的replace(10938)
3.?VS2005編譯libevent(10404)
4.?混音算法的學(xué)習(xí)與研究(10183)
5.?C調(diào)用lua腳本的效率測試(9003)
評論排行榜
1.?VC6正在被拋棄(35)
2.?VS2005編譯libevent(21)
3.?"multiple definition of" 錯誤(18)
4.?C++引用優(yōu)于指針(17)
5.?ACE與ASIO之間關(guān)于Socket編程的比較(16)
使用完成端口HTTP下載的代碼
使用完成端口HTTP下載的代碼
(轉(zhuǎn)載請注明來源于金慶的專欄)
試運行asio的async_client例程時,發(fā)現(xiàn)CPU占用很高,
所以又寫了一個相同功能但直接調(diào)用完成端口API的代碼,
進行比較,發(fā)現(xiàn)同樣占用CPU。
與flashget比較,下載速度差不多,但flashget不占CPU。
將直接API調(diào)用代碼和利用asio的代碼都列在下面。
進行測試時,要將其中的參數(shù)定義改改,如SERVER參數(shù)。
并且要找個大文件下載才有明顯結(jié)果。
#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內(nèi)部也使用了IOCP模式的通信機制,因此應(yīng)該是相似的結(jié)果
回復(fù)
更多評論
#
re: 使用完成端口HTTP下載的代碼
2011-08-19 15:34
金慶
只要有一個包到達,完成端口就執(zhí)行一次從緩沖里讀操作檢測執(zhí)行,而通常應(yīng)用,一個數(shù)據(jù)段會由很多包組成,這樣,內(nèi)核線程需要調(diào)度很多次,而如果使用非阻塞 SOCKET讀,通過定時檢查機制,可以避免這種內(nèi)部的頻繁調(diào)度. 參見: 網(wǎng)絡(luò)編程--走出完成端口的誤區(qū) (
http://blog.csdn.net/danscort2000/article/details/4703391
)
回復(fù)
更多評論
#
re: 使用完成端口HTTP下載的代碼
2013-04-17 00:30
cmi
通過運行博主的iocp寫的下載代碼,下載一個300m的文件,速度150~300k/s
cpu的占用率為0~1,沒有出現(xiàn)樓主所說cpu占用率很高的情況。
博主還記得你的問題到底是什么原因引起的嗎?
我在考慮是否要用iocp寫,看了博主提供的這篇文章
http://blog.csdn.net/danscort2000/article/details/4703391
,很是糾結(jié)。
我感覺這篇文章說的并不正確。
回復(fù)
更多評論
#
re: 使用完成端口HTTP下載的代碼
2013-12-16 16:39
金慶
@cmi
需要內(nèi)網(wǎng)測試,速度接近網(wǎng)絡(luò)帶寬。
回復(fù)
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
How are dtLinks created in NavMesh
C++ parameter passing rules
Naming Conventions for Accessors
Visual Studio 2019 Compiler Hangs
Fbx File Format Identifier
查找內(nèi)存錯誤
std::thread 中的異常會丟失調(diào)用棧
用賦值代替 protobuf CopyFrom()
vs2017 linux 編譯輸出改成 vs 格式
為 LiteIDE 添加選中標記
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 金慶
国产成人综合久久精品红
|
久久精品国产99久久丝袜
|
一本大道久久东京热无码AV
|
国产成人综合久久精品尤物
|
色综合合久久天天综合绕视看
|
www.久久热.com
|
久久精品九九亚洲精品天堂
|
久久久久久综合一区中文字幕
|
久久久久无码精品国产不卡
|
久久婷婷五月综合97色一本一本
|
热re99久久6国产精品免费
|
国产色综合久久无码有码
|
人妻精品久久久久中文字幕69
|
无码专区久久综合久中文字幕
|
色天使久久综合网天天
|
亚洲va久久久噜噜噜久久狠狠
|
久久影院综合精品
|
久久精品一区二区
|
四虎影视久久久免费
|
久久精品国产99国产精品亚洲
|
亚洲精品高清国产一线久久
|
波多野结衣中文字幕久久
|
91久久香蕉国产熟女线看
|
亚洲日本va午夜中文字幕久久
|
三级三级久久三级久久
|
69SEX久久精品国产麻豆
|
久久精品女人天堂AV麻
|
综合人妻久久一区二区精品
|
精品久久人妻av中文字幕
|
国产精品久久久久一区二区三区
|
国产精品免费久久久久影院
|
要久久爱在线免费观看
|
国产精品99精品久久免费
|
九九久久精品无码专区
|
少妇人妻88久久中文字幕
|
久久久久国产
|
精品综合久久久久久888蜜芽
|
久久夜色精品国产
|
久久777国产线看观看精品
|
国产精品久久久久久久久久影院
|
久久99精品综合国产首页
|