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

            勤能補拙,Expter

            成都游戲Coder,記錄游戲開發(fā)過程的筆記和心得!

            一個小型的IOCP網(wǎng)絡(luò)庫

                    基本網(wǎng)絡(luò)框架基于IOCP模型,這次主要在以前寫的IPC通信的基礎(chǔ)上修改,參考了當前項目網(wǎng)絡(luò)庫的設(shè)計思路。
                  
                     先介紹幾個主要的類:
                   1.CSocket重新套接字,CConnection繼承CSocket表示一個連接對象主要重寫Recv和Send接口,以及組包過程。
                   2.CAccept處理客戶端的鏈接,
                   3.Cpacket一個消息數(shù)據(jù)包頭,CMessage繼承CPacket帶數(shù)據(jù)消息包。
                   4.CConnectManger保存一個連接CConnection的內(nèi)存池對象,CAcceptManager一個接收客戶端Accept的線程,CPacketManager參考了Loki的小對象管理做的一個緩沖區(qū)數(shù)據(jù)包內(nèi)存池。
                   5.CLibObject包含上面3個Manager(Singleton),CNetWork網(wǎng)絡(luò)初始化。
                   6.CIOCP類主要IO的線程類,接收處理所有的客戶端連接CConnection。
                   7.CServer類包括一個IOCP初始化和網(wǎng)絡(luò)庫管理類,IOCP會把接收到的數(shù)據(jù)重組成數(shù)據(jù)包后保存到CServer的一個CMsgQueue中.
                   8.我們的重寫一個Server只需要繼承CServer,然后實現(xiàn)run和AccedeProcess即可。run從CMsgQueue緩沖區(qū)提取一個消息包,AccedeProcess處理消息。
                  一些細節(jié)設(shè)計:
                   1.為了節(jié)約帶寬Connection這里采用了Negles算法,這里采用Negle的并沒有馬上把每一個需要發(fā)送MSG采用緩存隊列的方式保存起來,而是每一個Connection自身都保存數(shù)據(jù),CServer通過一個線程把每一個存在的Connection是否有消息緩存,然后發(fā)送。因而讓IOCP只處理接收的消息,發(fā)送消息通過CServer來處理。

                    出網(wǎng)絡(luò)庫基本框架如下:
                      
             

            網(wǎng)絡(luò)庫代碼的代碼http://code.google.com/p/tpgame/source/browse/#svn/trunk/GServerEngine/NetLibrary

            問題肯定較多,希望多多指教。


            最近一直在構(gòu)思與寫一套游戲AI系統(tǒng),主要是通過狀態(tài)機響應事件,更多是想運用自己學習到的一些優(yōu)秀的算法,以及一些高級

            的AI以此來鍛煉對一些復雜的數(shù)據(jù)結(jié)構(gòu)的編寫和設(shè)計思維的提升。

            算法和數(shù)據(jù)結(jié)構(gòu)方面:
            1.2D和3D尋路(主要包括2D尋路的初始化條件優(yōu)化 ,3D的空間劃分以及多叉樹的劃分,以及堆維護)。
            2.帶有更多思維的角色系統(tǒng)(附帶更多的數(shù)據(jù)信息)判斷。
            3.查詢線段樹和樹狀數(shù)數(shù)組的運用。
            4.一個線性的字符串過濾程序。
            5.一個動態(tài)基于角色的最優(yōu)二叉查找樹的動態(tài)維護。(主要解決不同的角色AI觸發(fā)頻率建立一顆最優(yōu)二叉查找樹)
            6.追蹤算法以及游戲的群集算法都會整合到現(xiàn)在的AI系統(tǒng)中。

            設(shè)計方面:
            1.盡量讓類之間耦合性更小,復雜度更低,淺顯明確。

            注:Ai系統(tǒng)寫完會把代碼和網(wǎng)絡(luò)庫的最新代碼更新都會上傳,希望大家多多指教。




            posted on 2009-12-20 14:21 expter 閱讀(3778) 評論(5)  編輯 收藏 引用 所屬分類: 其他學習筆記 、工作筆記 、算法與數(shù)據(jù)結(jié)構(gòu)Ai

            評論

            # re: 一個小型的IOCP網(wǎng)絡(luò)庫 2009-12-21 01:50 Fox

            三更半夜的上來看一下,這兩天被蹂躪安逸了……  回復  更多評論   

            # re: 一個小型的IOCP網(wǎng)絡(luò)庫[未登錄] 2009-12-23 12:44 true

            友情支持  回復  更多評論   

            # re: 一個小型的IOCP網(wǎng)絡(luò)庫 2009-12-23 22:15 矩陣操作

            提供一個打包下載吧。不很想裝SVN。。。。-_-~!  回復  更多評論   

            # re: 一個小型的IOCP網(wǎng)絡(luò)庫 2010-10-07 16:02 favormm

            我也是成都coder  回復  更多評論   

            # re: 一個小型的IOCP網(wǎng)絡(luò)庫 2010-10-07 16:05 favormm

            學習了。我也是成都的  回復  更多評論   

            嫩草伊人久久精品少妇AV| 久久国语露脸国产精品电影| 久久免费视频观看| 久久久久国产亚洲AV麻豆| 2019久久久高清456| 久久99精品国产99久久6男男| 99久久国产免费福利| 免费无码国产欧美久久18| AAA级久久久精品无码片| 久久亚洲国产成人影院| 91麻豆精品国产91久久久久久| 久久亚洲国产成人影院| 国产成人香蕉久久久久| 久久精品国产第一区二区三区| 久久99精品国产麻豆蜜芽| 久久久久高潮毛片免费全部播放 | 国产美女久久精品香蕉69| 久久影院午夜理论片无码 | 亚洲乱码日产精品a级毛片久久 | 国产福利电影一区二区三区,免费久久久久久久精 | 国内精品久久久久| 人妻无码精品久久亚瑟影视 | 国产韩国精品一区二区三区久久 | 欧美久久亚洲精品| 国产L精品国产亚洲区久久| 精品久久久无码21p发布 | 久久精品二区| 亚洲天堂久久精品| 国产精品久久久福利| 久久不见久久见免费视频7| 久久人人爽人人爽人人av东京热| 久久精品成人欧美大片| 久久AⅤ人妻少妇嫩草影院| 91麻豆精品国产91久久久久久| 国产精品久久久久久福利69堂| 久久久无码精品亚洲日韩蜜臀浪潮| 国产亚洲美女精品久久久2020| 亚洲性久久久影院| 久久天天躁夜夜躁狠狠| 日本欧美久久久久免费播放网 | 久久99精品国产麻豆婷婷|