• <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>

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            epoll與iocp的異同

            目前國內(nèi)的網(wǎng)游研發(fā),在服務(wù)器使用的開發(fā)平臺方面,winlinux的比例各占多少,我一時半會也沒有準(zhǔn)確數(shù)據(jù),但從我了解的這么多公司情況來看,用 win系統(tǒng)的還是比較多一點,這些企業(yè)一般都是比較單純的網(wǎng)游公司,而用linux的則多數(shù)是一些傳統(tǒng)的互聯(lián)網(wǎng)公司,比如網(wǎng)易和騰訊。

            網(wǎng)游服務(wù)器用win還是linux,向來都是大家關(guān)注的話題。我想,原因可能很多,但此處不想過多論述這個問題,為避免多費口舌,我還是明確表明一下自己的觀點:我是推薦用linux作開發(fā)的,雖然我也是剛轉(zhuǎn)來作linux平臺下的開發(fā)。

            那么,說具體一點。但凡作過比較深入的網(wǎng)絡(luò)編程的人,都會知道,在win平臺下,高效的IO模型是IOCP,而在linux底下則是epoll。那么,epolliocp之間到底有哪些異同之處呢?

            首先,我們看一下它們相同的地方。

            兩者都是處理異步IO的高效模型,這種高效,除了“異步處理”這個共同的特征之外,二者都可以通過指針攜帶應(yīng)用層數(shù)據(jù):在IOCP里,應(yīng)用層數(shù)據(jù)可以通過單句柄數(shù)據(jù)和單IO數(shù)據(jù)來與IOCP底層通信;而在epoll里,可以通過epoll_data里的'void *ptr'來傳遞。這是一種很重要的思想,也是它們高效的原因所在:當(dāng)事件的通知到來時,它不僅告訴你發(fā)生了什么樣的事件,還同時告訴這次事件所操作的數(shù)據(jù)是哪些。

            那么,epolliocp到底又有什么不同呢?

            以我目前粗淺的使用經(jīng)驗來看,至少可以得到以下結(jié)論:

            1.iocp
            是在IO操作完成之后,才通過get函數(shù)返回這個完成通知的;而epoll則不是在IO操作完成之后才通知你,它的工作原理是,你如果想進行IO操作時,先向epoll查詢是否可讀或可寫,如果處于可讀或可寫狀態(tài)后,epoll會通過epoll_wait函數(shù)通知你,此時你再進行進一步的recvsend操作。

            2.
            1的基礎(chǔ)上,我們其實可以看到,epoll僅僅是一個異步事件的通知機制,其本身并不作任何的IO讀寫操作,它只負責(zé)告訴你是不是可以讀或可以寫了,而具體的讀寫操作,還要應(yīng)用層自己來作;但iocp的封裝就要多一些,它不僅會有完成之后的事件通知,更重要的是,它同時封裝了一部分的IO控制邏輯。從這一點上來看,iocp的封裝似乎更全面一點,但是,換個角度看,epoll僅提供這種機制也是非常好的,它保持了事件通知與IO操作之間彼此的獨立性,使得epoll的使用更加靈活。

            這只是我初步使用epoll開發(fā)過程中的體會,以后有更深的體會時還會發(fā)上來跟大家分享。

            posted on 2009-08-24 21:16 肥仔 閱讀(1864) 評論(1)  編輯 收藏 引用 所屬分類: 網(wǎng)絡(luò)編程

            評論

            # re: epoll與iocp的異同  回復(fù)  更多評論   

            你對iocp的理解太膚淺了,iocp最精華的莫過于對多線程的綁定能力,而epoll是沒有這個的,如libevent之類的庫居然按照epoll的模式,弄個所謂的socket消息轉(zhuǎn)發(fā)技巧來實現(xiàn)線程間通知,這在iocp看來就是畫蛇添足。

            2011-08-01 10:45 | 袁斌
            久久91综合国产91久久精品| 精品无码久久久久国产动漫3d| 亚洲国产另类久久久精品黑人| 久久九九久精品国产| 亚洲国产成人久久精品影视| 国产精品久久久久AV福利动漫| 麻豆亚洲AV永久无码精品久久| 波多野结衣AV无码久久一区| 久久精品国产免费观看| 久久久久久精品免费免费自慰| 区久久AAA片69亚洲| 久久久精品人妻一区二区三区蜜桃| 精品久久久久久久国产潘金莲| 三级韩国一区久久二区综合| 久久无码专区国产精品发布| 国产精品成人久久久| 久久夜色精品国产噜噜噜亚洲AV | 青青草原综合久久| 国产99久久九九精品无码| 久久久久九九精品影院| 国产成人精品综合久久久久| 奇米影视7777久久精品| 国产亚洲成人久久| 久久久久久午夜精品| 97久久久久人妻精品专区| 久久本道综合久久伊人| 少妇人妻综合久久中文字幕| 国产成人久久精品激情 | 久久精品无码专区免费青青| 99麻豆久久久国产精品免费| 欧美伊人久久大香线蕉综合69 | 伊人久久大香线蕉综合Av| 好属妞这里只有精品久久| 日韩久久久久中文字幕人妻| 人妻精品久久无码区| 久久国产精品免费一区| 嫩草伊人久久精品少妇AV| 久久夜色精品国产亚洲av| 久久久久久国产精品无码超碰 | 欧美日韩中文字幕久久久不卡| 久久精品国产亚洲AV大全|