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

隨筆-381  評論-37  文章-0  trackbacks-0
原帖:http://m.shnenglu.com/shanoa/archive/2009/06/26/88606.html 花了足足3天時間,外加1天心情休整,終于在第5天編寫出了一個能運行的基于asio和thread_group的框架,差點沒氣暈過去,把源碼都看懂了才感覺會用了。 測試了一下,debug下一萬次回應耗時800+毫秒,release下是200+毫秒,機器配置雙核2.5G英特爾,4個線程并行工作,無錯的感覺真好,再也不用擔心iocp出一些奇怪的問題啦,因為是巨人們寫的實現,呵呵。 進入正題,簡要說一下asio的實現原理吧。在win32平臺上,asio是基于IOCP技術實現的,我以前也用過IOCP,卻沒想到居然能擴展成這樣,真是神奇!在其他平臺下還會有別的方法去實現,具體見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 這部分代碼其實就在boost::asio::io_service類聲明中的最前面幾行,可以看見在不同平臺下,io_service類的實現將會不同。很顯然,windows平臺下當然是win_iocp_io_service類為實現了(不過我一開始還以為win_iocp_io_service是直接拿出來用的呢,還在疑惑這樣怎么有移植性呢?官方文檔也對該類只字不提,其實我卡殼就是卡在這里了,差點就直接用這個類了^_^!)。 那么就分析一下win_iocp_io_service的代碼吧,這里完全是用IOCP來路由各種任務,大家使用post來委托任務,內部調用的其實是IOCP的PostQueuedCompletionStatus函數,然后線程們用run來接受任務,內部其實是阻塞在IOCP的GetQueuedCompletionStatus函數上,一旦有了任務就立即返回,執行完后再一個循環,繼續阻塞在這里等待下一個任務的到來,這種設計思想堪稱神奇,對線程、服務以及任務完全解耦,靈活度達到了如此高度,不愧為boost庫的東西!我只能有拜的份了... 說一下總體的設計思想,其實io_service就像是勞工中介所,而一個線程就是一個勞工,而調用post的模塊相當于富人們,他們去中介所委托任務,而勞工們就聽候中介所的調遣去執行這些任務,任務的內容就寫在富人們給你的handler上,也就是函數指針,指針指向具體實現就是任務的實質內容。其實在整個過程中,富人們都不知道是哪個勞工幫他們做的工作,只知道是中介所負責完成這些就可以了。這使得邏輯上的耦合降到了最低。不過這樣的比喻也有個不恰當的地方,如果硬要這樣比喻的話,我只能說:其實勞工里面也有很多富人的^o^! 。很多勞工在完成任務的過程中自己也托給中介所一些任務,然后這些任務很可能還是自己去完成。這也難怪,運行代碼的總是這些線程,那么調用post的肯定也會有這些線程了,不過不管怎么說,如此循環往復可以解決問題就行,比喻不見得就得恰當,任何事物之間都不可能完全相同,只要能闡述思想就行。 最后還要說明的一點就是:委托的任務其實可以設定執行的時間的,很不錯的設定,內部實現則是通過定時器原理,GetQueuedCompletionStatus有一個等待時間的參數似乎被用在這方面,還有源碼中的定時器線程我并沒有過多的去理解,總之大體原理已基本掌握,剩下的就是使勁的用它了!!! 另外為了方便人交流,在這里插入一些代碼可能更容易讓人理解吧, 下面這個是啟動服務時的代碼: 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(); } 在打開前就得分配好任務,否則線程們運行起來就退出了,阻塞不住,任務的分配就交給open函數了,它是分配了監聽端口的任務,一旦有了連接就會拋出一個任務,其中一個線程就會開始行動啦。 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函數中給io_service的一個任務就是在有鏈接訪問服務器端口的情況下執行ServerFramework::__onConnect函數,有一點需要格外注意的,io_service必須時刻都有任務存在,否則線程io_service::run函數將返回,于是線程都會結束并銷毀,程序將退出,所以,你必須保證無論何時都有任務存在,這樣線程們即使空閑了也還是會繼續等待,不會銷毀。所以,我在ServerFramework::__onConnect函數中又一次給了io_service相同的任務,即:繼續監聽端口,有鏈接了還是調用ServerFramework::__onConnect函數。如果你在ServerFramework::__onConnect執行完了還沒有給io_service任務的話,那么一切都晚了...... 代碼如下: void ServerFramework::__onConnect(const BoostSysErr& e) { if (e) { MOELOG_DETAIL_WARN(e.message().c_str()); } Connection* p = mNextConnection; mNextConnection = new Connection(this); // 再次進入監聽狀態 mAcceptor.async_accept(mNextConnection->getSocket(), boost::bind(&ServerFramework::__onConnect, this, boost::asio::placeholders::error)); // 處理當前鏈接 __addConnection(p); p->start(); } 最后,展示一下這個類的所有成員變量吧: // 用于線程池異步處理的核心對象 boost::asio::io_service mIoService; // 網絡鏈接的接收器,用于接收請求進入的鏈接 boost::asio::ip::tcp::acceptor mAcceptor; // 指向下一個將要被使用的鏈接對象 Connection* mNextConnection; // 存儲服務器鏈接對象的容器 ConnectionSet mConnections; /**///// 為鏈接對象容器準備的strand,防止并行調用mConnections //boost::asio::io_service::strand mStrand_mConnections; // 為鏈接對象容器準備的同步鎖,防止并行調用mConnections boost::mutex mMutex4ConnSet; // 為控制臺輸出流準備的strand,防止并行調用std::cout AsioService::strand mStrand_ConsoleIostream; // 工作線程的數量 uint32 mWorkerCount; 但愿這篇隨筆也能對正在研究asio的朋友們有所幫助吧。
posted on 2009-08-02 01:05 小王 閱讀(688) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            亚洲自拍偷拍色片视频| 亚洲手机在线| 欧美性猛交xxxx乱大交退制版| 欧美v亚洲v综合ⅴ国产v| 牛夜精品久久久久久久99黑人| 麻豆av一区二区三区| 欧美国产精品v| 欧美三级免费| 国产欧美在线视频| 亚洲福利av| 99热免费精品在线观看| 欧美一区二区三区啪啪| 久久香蕉国产线看观看av| 欧美激情视频免费观看| 久久国产精品99精品国产| 欧美成年视频| 亚洲国产精品日韩| 亚洲欧洲一区二区三区| 国产精品99久久99久久久二8| 亚洲小视频在线| 久久蜜桃av一区精品变态类天堂| 欧美国产乱视频| 国产精品尤物福利片在线观看| 黑人操亚洲美女惩罚| 在线视频一区观看| 麻豆国产va免费精品高清在线| 日韩亚洲综合在线| 久久成人精品无人区| 欧美日韩成人综合天天影院| 国产亚洲福利| 亚洲香蕉在线观看| 欧美激情一区二区久久久| 香港成人在线视频| 欧美日韩国产一区精品一区| 黑人巨大精品欧美一区二区小视频 | 欧美经典一区二区| 国产伦理精品不卡| 一区二区高清视频| 亚洲成色精品| 久久久亚洲高清| 国产婷婷成人久久av免费高清| 夜夜爽av福利精品导航| 91久久综合| 欧美国产激情二区三区| 91久久在线视频| 欧美电影专区| 久久蜜桃精品| 亚洲国产裸拍裸体视频在线观看乱了中文 | 一本色道久久综合狠狠躁的推荐| 久久久午夜视频| 亚洲欧美日韩国产中文在线| 欧美日韩精品综合| 亚洲精品孕妇| 亚洲黄色天堂| 欧美黄色影院| 一本色道久久加勒比精品| 亚洲国产高清在线观看视频| 久久网站免费| 亚洲韩国青草视频| 亚洲国内精品| 国产精品久久久亚洲一区| 91久久精品国产91性色| 香蕉成人久久| 国产一区二区在线观看免费| 欧美一区二区三区免费观看| 午夜影院日韩| 在线成人亚洲| 亚洲国产另类久久精品| 欧美精品99| 亚洲淫片在线视频| 欧美在线视频观看| 亚洲国产精品99久久久久久久久| 欧美国产日韩一二三区| 欧美成人一区二区| 亚洲调教视频在线观看| 亚洲午夜女主播在线直播| 国产精品亚洲а∨天堂免在线| 性久久久久久久久| 久久美女艺术照精彩视频福利播放| 亚洲激情电影在线| 一本色道久久加勒比88综合| 国产日韩欧美高清| 亚洲国产成人av在线| 国产精品激情偷乱一区二区∴| 久久久999| 欧美日韩国产黄| 欧美一区二区在线视频| 麻豆9191精品国产| 亚洲网站视频福利| 久久久综合免费视频| 亚洲视频福利| 久久综合久久综合久久综合| 在线亚洲精品| 久久久久国色av免费看影院| 在线综合+亚洲+欧美中文字幕| 午夜日韩电影| 亚洲天堂网在线观看| 葵司免费一区二区三区四区五区| 亚洲一级免费视频| 免费看精品久久片| 欧美一区二区三区精品电影| 玖玖在线精品| 久久久久久亚洲精品中文字幕 | 91久久中文字幕| 亚洲综合日韩在线| 亚洲精品日韩综合观看成人91| 亚洲伊人久久综合| 中文一区字幕| 欧美二区在线| 欧美成人午夜激情在线| 国产精品手机视频| 一本色道久久综合亚洲精品按摩 | 亚洲一区二区三区色| 亚洲精品久久久久久久久久久久| 亚洲自拍电影| 亚洲一品av免费观看| 欧美一区二区网站| 久久综合图片| 久久er精品视频| 亚洲欧洲日产国产网站| 亚洲一二三区在线观看| 亚洲国产另类 国产精品国产免费| 国产日韩欧美中文| 国产欧美一区二区三区视频| 国产精品青草久久| 国产一区二区三区最好精华液| 国模私拍一区二区三区| 亚洲高清在线| 亚洲一区久久| 免费观看成人www动漫视频| 免费欧美高清视频| 亚洲高清123| 亚洲一区二区在线播放| 久久精品日产第一区二区三区| 久久视频精品在线| 欧美日韩国产片| 国产欧美精品xxxx另类| 亚洲激情女人| 久久久91精品国产一区二区精品| 免费不卡在线观看av| 在线视频欧美精品| 欧美国产一区二区| 国产精品国产三级国产专播品爱网 | 亚洲深夜av| 欧美 日韩 国产 一区| 亚洲欧美久久久| 欧美日韩精品福利| 日韩视频在线观看| 亚洲精品色图| 黄色成人片子| 久久午夜激情| 国产偷久久久精品专区| 欧美中文字幕精品| 欧美一级久久久| 国产一区二区三区黄视频| 欧美一区二区三区的| 香蕉av福利精品导航| 国产在线播放一区二区三区| 久久久久久久综合色一本| 亚洲伊人伊色伊影伊综合网| 欧美性jizz18性欧美| 欧美亚洲三区| 久久综合中文色婷婷| 亚洲乱码国产乱码精品精天堂 | 久久久久久电影| 在线日韩日本国产亚洲| 亚洲国产高清一区| 国产精品白丝jk黑袜喷水| 久久深夜福利免费观看| 欧美成人中文| 性伦欧美刺激片在线观看| 老司机67194精品线观看| 亚洲欧美国产视频| 欧美不卡视频一区| 久久久久综合网| 欧美日本韩国| 久久影音先锋| 国产精品乱码妇女bbbb| 欧美韩国日本一区| 国产一区91| 午夜精品在线视频| 亚洲欧美中文另类| 欧美理论视频| 欧美激情一二三区| 免费中文日韩| 亚洲啪啪91| 免费成人性网站| 欧美大片一区二区| 亚洲国产精品一区二区第一页| 午夜精品久久久久久久白皮肤| aⅴ色国产欧美| 久久久精品久久久久| 欧美丝袜一区二区| 亚洲精品日韩在线观看| 亚洲人精品午夜在线观看| 欧美成人精品激情在线观看| 免费成人美女女| 亚洲日本成人| 欧美色图五月天| 午夜激情综合网|