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

隨筆-381  評論-37  文章-0  trackbacks-0
原帖:http://m.shnenglu.com/shanoa/archive/2009/06/26/88606.html 花了足足3天時間,外加1天心情休整,終于在第5天編寫出了一個能運(yùn)行的基于asio和thread_group的框架,差點(diǎn)沒氣暈過去,把源碼都看懂了才感覺會用了。 測試了一下,debug下一萬次回應(yīng)耗時800+毫秒,release下是200+毫秒,機(jī)器配置雙核2.5G英特爾,4個線程并行工作,無錯的感覺真好,再也不用擔(dān)心iocp出一些奇怪的問題啦,因?yàn)槭蔷奕藗儗懙膶?shí)現(xiàn),呵呵。 進(jìn)入正題,簡要說一下asio的實(shí)現(xiàn)原理吧。在win32平臺上,asio是基于IOCP技術(shù)實(shí)現(xiàn)的,我以前也用過IOCP,卻沒想到居然能擴(kuò)展成這樣,真是神奇!在其他平臺下還會有別的方法去實(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 > impl_type; #elif defined(BOOST_ASIO_HAS_KQUEUE) typedef detail::task_io_service > impl_type; #elif defined(BOOST_ASIO_HAS_DEV_POLL) typedef detail::task_io_service > impl_type; #else typedef detail::task_io_service > impl_type; #endif 這部分代碼其實(shí)就在boost::asio::io_service類聲明中的最前面幾行,可以看見在不同平臺下,io_service類的實(shí)現(xiàn)將會不同。很顯然,windows平臺下當(dāng)然是win_iocp_io_service類為實(shí)現(xiàn)了(不過我一開始還以為win_iocp_io_service是直接拿出來用的呢,還在疑惑這樣怎么有移植性呢?官方文檔也對該類只字不提,其實(shí)我卡殼就是卡在這里了,差點(diǎn)就直接用這個類了^_^!)。 那么就分析一下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í)行完后再一個循環(huán),繼續(xù)阻塞在這里等待下一個任務(wù)的到來,這種設(shè)計(jì)思想堪稱神奇,對線程、服務(wù)以及任務(wù)完全解耦,靈活度達(dá)到了如此高度,不愧為boost庫的東西!我只能有拜的份了... 說一下總體的設(shè)計(jì)思想,其實(shí)io_service就像是勞工中介所,而一個線程就是一個勞工,而調(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í)在整個過程中,富人們都不知道是哪個勞工幫他們做的工作,只知道是中介所負(fù)責(zé)完成這些就可以了。這使得邏輯上的耦合降到了最低。不過這樣的比喻也有個不恰當(dāng)?shù)牡胤剑绻惨@樣比喻的話,我只能說:其實(shí)勞工里面也有很多富人的^o^! 。很多勞工在完成任務(wù)的過程中自己也托給中介所一些任務(wù),然后這些任務(wù)很可能還是自己去完成。這也難怪,運(yùn)行代碼的總是這些線程,那么調(diào)用post的肯定也會有這些線程了,不過不管怎么說,如此循環(huán)往復(fù)可以解決問題就行,比喻不見得就得恰當(dāng),任何事物之間都不可能完全相同,只要能闡述思想就行。 最后還要說明的一點(diǎn)就是:委托的任務(wù)其實(shí)可以設(shè)定執(zhí)行的時間的,很不錯的設(shè)定,內(nèi)部實(shí)現(xiàn)則是通過定時器原理,GetQueuedCompletionStatus有一個等待時間的參數(shù)似乎被用在這方面,還有源碼中的定時器線程我并沒有過多的去理解,總之大體原理已基本掌握,剩下的就是使勁的用它了!!! 另外為了方便人交流,在這里插入一些代碼可能更容易讓人理解吧, 下面這個是啟動服務(wù)時的代碼: 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ù),一旦有了連接就會拋出一個任務(wù),其中一個線程就會開始行動啦。 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的一個任務(wù)就是在有鏈接訪問服務(wù)器端口的情況下執(zhí)行ServerFramework::__onConnect函數(shù),有一點(diǎn)需要格外注意的,io_service必須時刻都有任務(wù)存在,否則線程io_service::run函數(shù)將返回,于是線程都會結(jié)束并銷毀,程序?qū)⑼顺觯裕惚仨毐WC無論何時都有任務(wù)存在,這樣線程們即使空閑了也還是會繼續(xù)等待,不會銷毀。所以,我在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(); } 最后,展示一下這個類的所有成員變量吧: // 用于線程池異步處理的核心對象 boost::asio::io_service mIoService; // 網(wǎng)絡(luò)鏈接的接收器,用于接收請求進(jìn)入的鏈接 boost::asio::ip::tcp::acceptor mAcceptor; // 指向下一個將要被使用的鏈接對象 Connection* mNextConnection; // 存儲服務(wù)器鏈接對象的容器 ConnectionSet mConnections; /**///// 為鏈接對象容器準(zhǔn)備的strand,防止并行調(diào)用mConnections //boost::asio::io_service::strand mStrand_mConnections; // 為鏈接對象容器準(zhǔn)備的同步鎖,防止并行調(diào)用mConnections boost::mutex mMutex4ConnSet; // 為控制臺輸出流準(zhǔn)備的strand,防止并行調(diào)用std::cout AsioService::strand mStrand_ConsoleIostream; // 工作線程的數(shù)量 uint32 mWorkerCount; 但愿這篇隨筆也能對正在研究asio的朋友們有所幫助吧。
posted on 2009-08-02 01:05 小王 閱讀(688) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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ⅴ99久久黑人专区| 欧美国产日韩在线| 亚洲一区二区在线免费观看| 欧美国产免费| 亚洲大片av| 国产精品毛片va一区二区三区| 亚洲日本va午夜在线电影| 99亚洲一区二区| 麻豆freexxxx性91精品| 欧美福利电影网| 欧美一区二区精品| 国产在线欧美| 欧美一区激情视频在线观看| 在线不卡亚洲| 在线播放国产一区中文字幕剧情欧美| 久久这里有精品视频| 久久影院午夜论| 欧美综合二区| 亚洲一区二区三区午夜| 亚洲一区二区在线免费观看| 亚洲第一福利视频| 在线看片成人| 亚洲精品综合精品自拍| 亚洲一区二区三区国产| 亚洲精品男同| 亚洲一区二区在线视频| 欧美影视一区| 亚洲精品一二| 午夜久久福利| 欧美高清视频免费观看| 亚洲成人资源网| 日韩视频精品在线| 欧美伊人久久| 久久成人精品电影| 一区二区三区产品免费精品久久75| 欧美国产精品va在线观看| 亚洲一区二区三区三| 欧美日韩mv| 亚洲精品永久免费| 国产精品每日更新| 国产伦精品一区二区三区四区免费| 久久免费黄色| 亚洲美女淫视频| 亚洲国产乱码最新视频| 国产精品久99| 国产一区二区三区视频在线观看| 亚洲午夜激情网页| 亚洲图片你懂的| 国产麻豆午夜三级精品| 国产精品九九久久久久久久| 亚洲国产成人tv| 影音先锋亚洲视频| 亚洲精品视频二区| 韩国一区电影| 韩国精品久久久999| 在线电影一区| 91久久国产综合久久| 欧美亚洲视频| 在线视频日韩| 国产日韩在线亚洲字幕中文| 在线视频欧美日韩| 久久精品免费看| 欧美综合激情网| 中文精品视频| 黑人操亚洲美女惩罚| 午夜视频在线观看一区二区| 亚洲免费观看高清完整版在线观看熊 | 亚洲国产一区二区视频| 欧美日韩国产综合一区二区| 欧美激情一区二区三区高清视频| 亚洲免费在线观看视频| 欧美成人精品一区| 久久婷婷蜜乳一本欲蜜臀| 狠狠色伊人亚洲综合成人| 久久精品一区四区| 亚洲免费精彩视频| 欧美午夜精品久久久久久人妖| 性欧美精品高清| 久久综合伊人77777| 欧美成人精品在线观看| 尤物yw午夜国产精品视频明星| 欧美在线观看视频一区二区| 亚洲在线国产日韩欧美| 日韩视频亚洲视频| 欧美亚男人的天堂| 亚洲精品国产精品乱码不99| 国产日韩久久| 亚洲综合激情| 性一交一乱一区二区洋洋av| 亚洲欧美日韩国产成人精品影院| 欧美日韩亚洲精品内裤| 日韩视频中文| 国产精品女人久久久久久| 亚洲性感激情| 亚洲国产日韩欧美在线99| 国产精品高潮呻吟久久av无限| 亚洲精品视频中文字幕| 国产一区二区丝袜高跟鞋图片| 欧美一区二区高清| 99v久久综合狠狠综合久久| 欧美少妇一区| 亚洲国产美女久久久久| 一区二区三区我不卡| 亚洲精品日韩精品| 99在线|亚洲一区二区| 亚洲一区国产视频| 加勒比av一区二区| 久久动漫亚洲| 亚洲欧美日韩国产成人| 亚洲嫩草精品久久| 亚洲第一伊人| 亚洲制服av| 亚洲国产成人在线视频| 亚洲精品一区二区网址| 国产伦精品一区二区三区在线观看| 亚洲国产午夜| 性视频1819p久久| 在线日韩电影| 欧美一区在线直播| 欧美激情一区二区三区四区| 亚洲国产美女精品久久久久∴| 久久亚洲一区二区三区四区| 欧美一区=区| 国产欧美日韩精品丝袜高跟鞋| 99www免费人成精品| 久久综合久久综合九色| 国产精品99久久久久久久久 | 午夜精品免费视频| 一本在线高清不卡dvd | 亚洲国产精品第一区二区三区| 久久婷婷久久| 亚洲电影毛片| 99精品免费网| 亚洲人成小说网站色在线| 欧美色精品天天在线观看视频| 亚洲精选国产| 久久久欧美精品sm网站| 国产欧美日韩精品专区| 欧美在线一二三四区| 欧美视频中文一区二区三区在线观看 | 欧美日韩日日骚| 在线一区二区日韩| 亚洲天堂免费在线观看视频| 亚洲激情六月丁香| 亚洲精品日产精品乱码不卡| 日韩亚洲视频在线| 国产亚洲欧美日韩在线一区| 99国内精品| 亚洲精品自在久久| 欧美亚洲一区二区在线| 99av国产精品欲麻豆| 亚洲国产高清高潮精品美女| 国产精品私房写真福利视频| 国产自产女人91一区在线观看| 亚洲一卡二卡三卡四卡五卡| 免费观看成人www动漫视频| 伊人久久综合| 亚洲国产精品va在线看黑人| 一区二区在线视频播放| 亚洲人精品午夜| 亚洲人精品午夜在线观看| 亚洲系列中文字幕| 国产精品家教| 国产日韩精品一区| 亚洲国产老妈| 久久成人av少妇免费| 亚洲成色精品| 久久精品九九| 国产一区二区精品久久| 美国十次了思思久久精品导航| 欧美激情综合色| 在线午夜精品| 国产精品一香蕉国产线看观看| 免费观看久久久4p| 激情视频一区| 国产精品久久久久久久久久三级| 国产精品成人播放| 亚洲黄一区二区| 一区二区三区三区在线| 久久久久一区二区| 国产农村妇女精品一二区| 亚洲自拍三区| 欧美成人亚洲成人日韩成人| 99国产精品99久久久久久粉嫩| 欧美综合77777色婷婷| 国产欧美二区| 91久久久久久国产精品| 久久久夜精品| 香蕉成人啪国产精品视频综合网| 亚洲午夜精品17c| 国产精品美女久久福利网站| 亚洲欧美精品suv| 亚洲欧洲日产国产网站| 国产精品揄拍一区二区| 亚洲破处大片| 亚洲精品视频在线观看免费|