青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ACG狂人

其實(shí)我更愛姐汁...

ASIO攻破!!!

花了足足3天時(shí)間,外加1天心情休整,終于在第5天編寫出了一個(gè)能運(yùn)行的基于asio和thread_group的框架,差點(diǎn)沒氣暈過去,把源碼都看懂了才感覺會(huì)用了。
測(cè)試了一下,debug下一萬(wàn)次回應(yīng)耗時(shí)800+毫秒,release下是200+毫秒,機(jī)器配置雙核2.5G英特爾,4個(gè)線程并行工作,無(wú)錯(cuò)的感覺真好,再也不用擔(dān)心iocp出一些奇怪的問題啦,因?yàn)槭蔷奕藗儗懙膶?shí)現(xiàn),呵呵。

進(jìn)入正題,簡(jiǎn)要說一下asio的實(shí)現(xiàn)原理吧。在win32平臺(tái)上,asio是基于IOCP技術(shù)實(shí)現(xiàn)的,我以前也用過IOCP,卻沒想到居然能擴(kuò)展成這樣,真是神奇!在其他平臺(tái)下還會(huì)有別的方法去實(shí)現(xiàn),具體見io_service類下面這部分的源碼:
  // The type of the platform-specific implementation.
#if defined(BOOST_ASIO_HAS_IOCP)
  typedef detail::win_iocp_io_service impl_type;
  friend 
class detail::win_iocp_overlapped_ptr;
#elif defined(BOOST_ASIO_HAS_EPOLL)
  typedef detail::task_io_service
<detail::epoll_reactor<false> > impl_type;
#elif defined(BOOST_ASIO_HAS_KQUEUE)
  typedef detail::task_io_service
<detail::kqueue_reactor<false> > impl_type;
#elif defined(BOOST_ASIO_HAS_DEV_POLL)
  typedef detail::task_io_service
<detail::dev_poll_reactor<false> > impl_type;
#else
  typedef detail::task_io_service
<detail::select_reactor<false> > impl_type;
#endif
這部分代碼其實(shí)就在boost::asio::io_service類聲明中的最前面幾行,可以看見在不同平臺(tái)下,io_service類的實(shí)現(xiàn)將會(huì)不同。很顯然,windows平臺(tái)下當(dāng)然是win_iocp_io_service類為實(shí)現(xiàn)了(不過我一開始還以為win_iocp_io_service是直接拿出來用的呢,還在疑惑這樣怎么有移植性呢?官方文檔也對(duì)該類只字不提,其實(shí)我卡殼就是卡在這里了,差點(diǎn)就直接用這個(gè)類了^_^!)。

那么就分析一下win_iocp_io_service的代碼吧,這里完全是用IOCP來路由各種任務(wù),大家使用post來委托任務(wù),內(nèi)部調(diào)用的其實(shí)是IOCP的PostQueuedCompletionStatus函數(shù),然后線程們用run來接受任務(wù),內(nèi)部其實(shí)是阻塞在IOCP的GetQueuedCompletionStatus函數(shù)上,一旦有了任務(wù)就立即返回,執(zhí)行完后再一個(gè)循環(huán),繼續(xù)阻塞在這里等待下一個(gè)任務(wù)的到來,這種設(shè)計(jì)思想堪稱神奇,對(duì)線程、服務(wù)以及任務(wù)完全解耦,靈活度達(dá)到了如此高度,不愧為boost庫(kù)的東西!我只能有拜的份了...

說一下總體的設(shè)計(jì)思想,其實(shí)io_service就像是勞工中介所,而一個(gè)線程就是一個(gè)勞工,而調(diào)用post的模塊相當(dāng)于富人們,他們?nèi)ブ薪樗腥蝿?wù),而勞工們就聽候中介所的調(diào)遣去執(zhí)行這些任務(wù),任務(wù)的內(nèi)容就寫在富人們給你的handler上,也就是函數(shù)指針,指針指向具體實(shí)現(xiàn)就是任務(wù)的實(shí)質(zhì)內(nèi)容。其實(shí)在整個(gè)過程中,富人們都不知道是哪個(gè)勞工幫他們做的工作,只知道是中介所負(fù)責(zé)完成這些就可以了。這使得邏輯上的耦合降到了最低。不過這樣的比喻也有個(gè)不恰當(dāng)?shù)牡胤剑绻惨@樣比喻的話,我只能說:其實(shí)勞工里面也有很多富人的^o^! 。很多勞工在完成任務(wù)的過程中自己也托給中介所一些任務(wù),然后這些任務(wù)很可能還是自己去完成。這也難怪,運(yùn)行代碼的總是這些線程,那么調(diào)用post的肯定也會(huì)有這些線程了,不過不管怎么說,如此循環(huán)往復(fù)可以解決問題就行,比喻不見得就得恰當(dāng),任何事物之間都不可能完全相同,只要能闡述思想就行。

最后還要說明的一點(diǎn)就是:委托的任務(wù)其實(shí)可以設(shè)定執(zhí)行的時(shí)間的,很不錯(cuò)的設(shè)定,內(nèi)部實(shí)現(xiàn)則是通過定時(shí)器原理,GetQueuedCompletionStatus有一個(gè)等待時(shí)間的參數(shù)似乎被用在這方面,還有源碼中的定時(shí)器線程我并沒有過多的去理解,總之大體原理已基本掌握,剩下的就是使勁的用它了!!!

另外為了方便人交流,在這里插入一些代碼可能更容易讓人理解吧,
下面這個(gè)是啟動(dòng)服務(wù)時(shí)的代碼:
void ServerFramework::run()
{
    boost::thread_group workers;
    
for (uint32 i = 0; i < mWorkerCount; ++i)
        workers.create_thread(
            boost::bind(
&boost::asio::io_service::run, &mIoService));
    workers.join_all();
}

在打開前就得分配好任務(wù),否則線程們運(yùn)行起來就退出了,阻塞不住,任務(wù)的分配就交給open函數(shù)了,它是分配了監(jiān)聽端口的任務(wù),一旦有了連接就會(huì)拋出一個(gè)任務(wù),其中一個(gè)線程就會(huì)開始行動(dòng)啦。
void ServerFramework::open(const String& address, const String& port, uint32 nWorkers /*= DEFAULT_WORKER_COUNT*/)
{
    
// Open the acceptor with the option to reuse the address (i.e. SO_REUSEADDR).
    boost::asio::ip::tcp::resolver resolver(mIoService);
    boost::asio::ip::tcp::resolver::query query(address, port);
    boost::asio::ip::tcp::endpoint endpoint 
= *resolver.resolve(query);

    mAcceptor.open(endpoint.protocol());
    mAcceptor.set_option(boost::asio::ip::tcp::acceptor::reuse_address(
true));
    mAcceptor.bind(endpoint);
    mAcceptor.listen();

    mNextConnection 
= new Connection(this);
    mAcceptor.async_accept(mNextConnection
->getSocket(),
        boost::bind(
&ServerFramework::__onConnect, this,
        boost::asio::placeholders::error));

    mWorkerCount 
= nWorkers;
    
if (mWorkerCount == DEFAULT_WORKER_COUNT)
    
{
        mWorkerCount 
= 4;
    }

}

open函數(shù)中給io_service的一個(gè)任務(wù)就是在有鏈接訪問服務(wù)器端口的情況下執(zhí)行ServerFramework::__onConnect函數(shù),有一點(diǎn)需要格外注意的,io_service必須時(shí)刻都有任務(wù)存在,否則線程io_service::run函數(shù)將返回,于是線程都會(huì)結(jié)束并銷毀,程序?qū)⑼顺觯裕惚仨毐WC無(wú)論何時(shí)都有任務(wù)存在,這樣線程們即使空閑了也還是會(huì)繼續(xù)等待,不會(huì)銷毀。所以,我在ServerFramework::__onConnect函數(shù)中又一次給了io_service相同的任務(wù),即:繼續(xù)監(jiān)聽端口,有鏈接了還是調(diào)用ServerFramework::__onConnect函數(shù)。如果你在ServerFramework::__onConnect執(zhí)行完了還沒有給io_service任務(wù)的話,那么一切都晚了...... 代碼如下:
void ServerFramework::__onConnect(const BoostSysErr& e)
{
    
if (e)
    
{
        MOELOG_DETAIL_WARN(e.message().c_str());
    }


    Connection
* p = mNextConnection;
    mNextConnection 
= new Connection(this);

    
// 再次進(jìn)入監(jiān)聽狀態(tài)
    mAcceptor.async_accept(mNextConnection->getSocket(),
        boost::bind(
&ServerFramework::__onConnect, this,
        boost::asio::placeholders::error));

    
// 處理當(dāng)前鏈接
    __addConnection(p);
    p
->start();
}

最后,展示一下這個(gè)類的所有成員變量吧:
    // 用于線程池異步處理的核心對(duì)象
    boost::asio::io_service mIoService;

    
// 網(wǎng)絡(luò)鏈接的接收器,用于接收請(qǐng)求進(jìn)入的鏈接
    boost::asio::ip::tcp::acceptor mAcceptor;

    
// 指向下一個(gè)將要被使用的鏈接對(duì)象
    Connection* mNextConnection;

    
// 存儲(chǔ)服務(wù)器鏈接對(duì)象的容器
    ConnectionSet mConnections;

    
//// 為鏈接對(duì)象容器準(zhǔn)備的strand,防止并行調(diào)用mConnections
    //boost::asio::io_service::strand mStrand_mConnections;

    
// 為鏈接對(duì)象容器準(zhǔn)備的同步鎖,防止并行調(diào)用mConnections
    boost::mutex mMutex4ConnSet;

    
// 為控制臺(tái)輸出流準(zhǔn)備的strand,防止并行調(diào)用std::cout
    AsioService::strand mStrand_ConsoleIostream;

    
// 工作線程的數(shù)量
    uint32 mWorkerCount;



但愿這篇隨筆也能對(duì)正在研究asio的朋友們有所幫助吧。

posted on 2009-06-26 22:14 釀妹汁 閱讀(9977) 評(píng)論(15)  編輯 收藏 引用 所屬分類: C++

評(píng)論

# re: ASIO攻破!!! 2009-06-27 09:40 zhaoyang0618

感謝!也在學(xué)習(xí)ASIO。
能否簡(jiǎn)單的說一下如何在ASIO中使用thread_group呢?或者說在ASIO中使用線城池。  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2009-06-30 17:15 亨德列克

高  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2009-07-04 16:03

@zhaoyang0618
其實(shí)asio將線程與框架分離了開來,但是會(huì)在內(nèi)部輔助你進(jìn)行同步調(diào)用,完全不用你去擔(dān)心。你只要在線程的主函數(shù)中調(diào)用io_service::run方法就可以了,或者干脆將io_service::run當(dāng)成線程的主函數(shù)也行,就像我所用的方法一樣:
boost::thread_group workers;
for (uint32 i = 0; i < mWorkerCount; ++i)
workers.create_thread(
boost::bind(&boost::asio::io_service::run, &mIoService));
workers.join_all();  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2009-07-04 16:26

@zhaoyang0618
博客正文已經(jīng)添加了新的內(nèi)容,還望能指正。  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2009-07-04 17:06 99網(wǎng)上書店

開源軟件的領(lǐng)袖和先驅(qū),從來沒有領(lǐng)過一天工資  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2009-07-05 23:27 99書城

能否簡(jiǎn)單的說一下如何在ASIO中使用thread_group呢  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!![未登錄] 2009-09-02 21:17 ace

喜歡用ace  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2009-10-27 16:14 dc

為什么我一直覺得asio似乎并沒有將io/work分開呢?
按照這種async模型的話,只要work卡住不去執(zhí)行async_recv的話一直無(wú)法從網(wǎng)絡(luò)緩沖區(qū)中提取出packet,最終可能導(dǎo)致緩沖區(qū)飽和?  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2009-10-27 16:16 dc

不是數(shù)據(jù)包緩沖區(qū)..是io消息列隊(duì)..  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2010-11-05 16:41 冬瓜

為了防止io_service.run退出,可以增加一個(gè)work,這樣它就可以使它一直處理boost::asio::io_service::work  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!![未登錄] 2012-08-30 13:21 jason

你好,能給我一份關(guān)于boost的IOCP,完整的代碼嗎?對(duì)我而言,特別重要,希望大蝦幫助。  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!![未登錄] 2012-08-30 13:23 jason

我的郵件是zxl200406@163.com
謝謝您的幫助。  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2012-09-18 23:05 shanoa

@jason
boost源碼里有的呀,你上www.boost.org下載boost源碼吧  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!![未登錄] 2013-07-10 16:34 stonexin

mAcceptor.bind(endpoint);

這一行代碼最好做個(gè)判斷,加上error_code.不然ip地址或者端口不正確,會(huì)導(dǎo)致意外的崩潰。
boost::system::error_code ec;
mAcceptor.bind(endpoint,ec);
if(ec)
{
std::cout<<"error: "<<ec.message()<<std::endl;
}  回復(fù)  更多評(píng)論   

# re: ASIO攻破!!! 2013-08-16 17:24 feelworld

你好 能給一份實(shí)現(xiàn)這個(gè)框架的代碼嗎 不勝感激 276090345@qq.com  回復(fù)  更多評(píng)論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久噜久噜久久综合| 国产日韩欧美综合精品| 日韩午夜免费视频| 亚洲一区二区三区三| 国产精品免费aⅴ片在线观看| 亚洲欧美另类在线| 久久久免费观看视频| 亚洲黄色三级| 欧美午夜宅男影院在线观看| 亚洲欧美电影院| 欧美黄色大片网站| 午夜精品理论片| 亚洲国产日韩一区| 国产精品成人一区二区三区夜夜夜| 香蕉成人久久| 亚洲人成亚洲人成在线观看| 香蕉av福利精品导航| 在线看成人片| 国产精品男人爽免费视频1| 久久激情五月丁香伊人| 亚洲精品日韩综合观看成人91| 亚洲欧美制服中文字幕| 亚洲国产一区二区视频| 国产精品毛片a∨一区二区三区| 久久精品亚洲一区二区三区浴池| 亚洲三级色网| 麻豆精品传媒视频| 午夜精品视频在线| 亚洲欧洲精品一区二区三区不卡 | 欧美成人一区二区三区片免费| 亚洲四色影视在线观看| 在线免费观看日本一区| 欧美三级特黄| 久热精品视频在线| 午夜影院日韩| 一区二区三区欧美激情| 欧美激情亚洲自拍| 久久久噜久噜久久综合| 午夜久久99| 一区二区三区四区五区在线 | 亚洲精品一区二区三区不| 久久av在线| 亚洲一区久久久| 日韩午夜黄色| 亚洲日韩欧美视频一区| 国精品一区二区| 国产精品普通话对白| 欧美日韩一区二区三区高清| 欧美成人免费小视频| 久久国产综合精品| 欧美一级成年大片在线观看| 日韩网站在线看片你懂的| 欧美国产精品v| 美女视频网站黄色亚洲| 久久人人看视频| 久久精品夜色噜噜亚洲a∨| 亚洲一区久久| 亚洲综合色在线| 中日韩视频在线观看| 日韩亚洲国产欧美| 亚洲久久一区| 亚洲精品综合在线| 日韩网站在线| 在线视频日韩| 亚洲视频欧美在线| 中文在线资源观看视频网站免费不卡| 亚洲精品一区在线观看香蕉| 亚洲精品国久久99热| 亚洲激情欧美| 日韩一级精品| 亚洲无吗在线| 香蕉成人伊视频在线观看 | 亚洲精品国产精品国自产观看| 伊人影院久久| 亚洲国产高清高潮精品美女| 亚洲二区在线视频| 亚洲日本中文| 亚洲社区在线观看| 亚洲欧美综合v| 久久国产婷婷国产香蕉| 久久免费黄色| 亚洲第一综合天堂另类专| 亚洲国产专区校园欧美| av成人老司机| 午夜日韩在线观看| 久久久久.com| 欧美激情aⅴ一区二区三区| 欧美日韩直播| 国产尤物精品| 亚洲激情欧美| 亚洲一区免费视频| 久久精品视频在线观看| 欧美国产第一页| 一本久道久久综合狠狠爱| 亚洲综合好骚| 免费观看一级特黄欧美大片| 欧美精品一区二区久久婷婷| 欧美天天视频| 好吊日精品视频| 夜夜狂射影院欧美极品| 欧美亚洲在线观看| 欧美成人午夜激情| 亚洲天堂av图片| 久久亚洲精品一区| 欧美日韩综合网| 韩日欧美一区二区| 国产精品99久久久久久有的能看| 欧美一区精品| 亚洲国产一区视频| 欧美一区二区三区日韩| 欧美不卡福利| 国产主播喷水一区二区| 野花国产精品入口| 久久米奇亚洲| 99伊人成综合| 免费在线成人av| 国产免费成人在线视频| 亚洲美女性视频| 久久综合色天天久久综合图片| 亚洲毛片av在线| 久久天堂成人| 国产偷国产偷亚洲高清97cao| 日韩视频二区| 麻豆精品在线视频| 亚洲欧美另类综合偷拍| 欧美理论在线| 在线精品视频一区二区| 久久成人国产精品| 亚洲精品亚洲人成人网| 另类天堂av| 国产曰批免费观看久久久| 亚洲午夜一二三区视频| 亚洲国产精品电影在线观看| 性欧美大战久久久久久久免费观看 | 国产精品日韩久久久| 亚洲精品网址在线观看| 久久另类ts人妖一区二区| 亚洲视频在线一区| 欧美美女bbbb| 亚洲精品偷拍| 欧美成人精精品一区二区频| 欧美在线观看网站| 国产女主播一区二区| 亚洲一品av免费观看| 亚洲国产视频一区二区| 久热re这里精品视频在线6| 国产综合视频| 久久久一区二区三区| 亚洲欧美日韩综合一区| 国产精品手机视频| 亚洲女性喷水在线观看一区| 亚洲乱码视频| 欧美日韩一区二区视频在线| 日韩亚洲视频在线| 亚洲人成小说网站色在线| 欧美成人免费在线| 99re66热这里只有精品4| 亚洲国产精品悠悠久久琪琪| 美女精品在线| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美成人精品一区二区三区| 美女视频网站黄色亚洲| 亚洲国产mv| 亚洲福利视频在线| 欧美精品在线免费播放| 一区二区三区视频在线| 一区二区三区四区五区精品视频| 欧美日韩一区二区三区| 性欧美videos另类喷潮| 午夜精品福利一区二区三区av| 国产欧美精品日韩| 久久美女艺术照精彩视频福利播放| 久久精品99国产精品日本| 在线观看欧美精品| 最新成人av在线| 国产精品v欧美精品v日韩精品| 午夜在线播放视频欧美| 久久国产日韩| 亚洲人成77777在线观看网| 亚洲黄色三级| 国产精品久久亚洲7777| 久久久噜噜噜久久| 欧美国产欧美综合 | 久久久精品国产一区二区三区| 欧美有码在线观看视频| 亚洲高清视频在线观看| 亚洲精品视频在线看| 国产情人综合久久777777| 欧美福利精品| 国产精品久久久久久一区二区三区| 欧美亚洲色图校园春色| 久久久久一区二区| 一本一本a久久| 午夜视频在线观看一区二区三区| 亚洲第一成人在线| 99国产精品| 好看的日韩视频| 99精品欧美一区二区三区| 国产一区二区精品久久99| 欧美激情bt|