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

            戰(zhàn)魂小筑

            討論群:309800774 知乎關(guān)注:http://zhihu.com/people/sunicdavy 開(kāi)源項(xiàng)目:https://github.com/davyxu

               :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              257 隨筆 :: 0 文章 :: 506 評(píng)論 :: 0 Trackbacks

                由于書(shū)寫(xiě)習(xí)慣,現(xiàn)在項(xiàng)目里依然使用我原來(lái)習(xí)慣的頭文件定義協(xié)議結(jié)構(gòu)體的方式:

            struct EnterLobbyREQ : public ProtocolHeader

            {

                    char mSessionID[64];

            }

            這種寫(xiě)法比較傳統(tǒng),有以下優(yōu)點(diǎn):

            1. 確實(shí)叫協(xié)議,帶頭文件,如果協(xié)議有修改,客戶端和服務(wù)器代碼馬上能看得出來(lái)
            2. 可以在結(jié)構(gòu)體里添加一些自動(dòng)填充size,type等的構(gòu)造函數(shù)和一些自動(dòng)計(jì)算變長(zhǎng)包大小的函數(shù),減少拷貝代碼出現(xiàn)的錯(cuò)誤
            3. 書(shū)寫(xiě)直觀,初學(xué)者容易理解

            但也有以下缺點(diǎn):

            1. 一個(gè)修改可能導(dǎo)致全盤(pán)重編
            2. 發(fā)送復(fù)雜結(jié)構(gòu)的數(shù)據(jù)不靈活:

              如果只想發(fā)送10-20個(gè)成員的結(jié)構(gòu)體里的7,8個(gè)成員,就需要寫(xiě)很多的賦值表達(dá)式,而且這樣的代碼充斥整個(gè)工程

             

                比較流行的寫(xiě)法就是流式寫(xiě)包,在有些工程里叫ProtocolComposer

            void Foo (ProtocolComposer& composer)

            {

                    composer << pos << action ;

            }

                其優(yōu)點(diǎn)顯而易見(jiàn):

            1. 協(xié)議可以只是一些注釋,客戶端和服務(wù)器只需要約定俗成就可以,修改協(xié)議無(wú)需重編
            2. 可以在復(fù)雜結(jié)構(gòu)中自由構(gòu)造發(fā)包內(nèi)容,拷貝復(fù)制方便自如
            3. 自由制作變長(zhǎng)包及類型決定包內(nèi)容種類等

             

            但其缺點(diǎn)也是有的:

            1. 一端修改協(xié)議后,另外一端若不及時(shí)修改,在編譯期將無(wú)法發(fā)現(xiàn),如果最后在運(yùn)行期暫時(shí)沒(méi)有報(bào)錯(cuò),將形成bug
            2. 組包速度慢于前者,對(duì)C++類型的代碼支持較好,但是c方式接受較為麻煩

             

            總的來(lái)說(shuō),后者還是為很多項(xiàng)目所用,所以下一個(gè)項(xiàng)目將啟用后者進(jìn)行編寫(xiě),希望能得到更好的游戲邏輯編寫(xiě)體驗(yàn)。如果有更好的建議可以回復(fù)。

            爱做久久久久久| 久久国产精品成人片免费| 久久精品国产精品亚洲| 亚洲人成无码网站久久99热国产 | 一本色道久久HEZYO无码| 久久人妻少妇嫩草AV无码专区| 久久91精品国产91久久户| 国产99久久久国产精品小说| 99久久精品日本一区二区免费| 99久久精品免费看国产一区二区三区| 亚洲美日韩Av中文字幕无码久久久妻妇 | 日本国产精品久久| 国产精品久久一区二区三区| 一级做a爰片久久毛片毛片| 久久国产精品99久久久久久老狼| 久久天天躁狠狠躁夜夜2020老熟妇 | 国产精品99久久99久久久| 久久婷婷五月综合97色直播| 99久久精品毛片免费播放| 久久夜色精品国产亚洲av| 亚洲国产精品婷婷久久| 亚洲欧美成人综合久久久 | 国产99久久久国产精品小说| 国产国产成人久久精品| 99久久中文字幕| 国产91色综合久久免费分享| 精品无码久久久久国产动漫3d| 中文字幕无码av激情不卡久久| 超级碰久久免费公开视频| 88久久精品无码一区二区毛片 | 蜜臀av性久久久久蜜臀aⅴ| 狠狠色丁香婷婷久久综合| 久久久久久精品免费看SSS| 久久夜色撩人精品国产| 国产精品中文久久久久久久| 精品久久久久久国产免费了| 国产精品gz久久久| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久99精品久久久久久hb无码 | 亚州日韩精品专区久久久| 久久天天躁狠狠躁夜夜avapp |