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

            常見cs程序自定義數(shù)據(jù)包描述

             

            常見cs程序自定義包可分為塊型包、非塊型包,非塊型包如http協(xié)議的,用\r\n\r\n結(jié)束,我們這里重點討論塊型包,塊型包常見頭部如下:

            Struct PKHEAD

            {

                    Union

            {

                            DWORD type;

                            Struct

            {

                    WORD mtype;

                    WORD stype;

            };

                    };

                    DWORD len;

                    Char buf[0];

            };

            內(nèi)容buf部分常見組織方式莫過于定長、變長兩種。定長的很簡單,如struct item{…};作為內(nèi)容部分,如果不涉及到高低序問題很好辦,涉及到序的時候轉(zhuǎn)換一下。變長部分常見組織方式有這么一些經(jīng)典方法:

            1、 Content1 \0 content2 \0 content3 \0 …

            2、 json描述。

            3、 xml描述。

            方法1是效率很高的,對ansi型字符串或者utf8型字符串都沒有問題,對utf16型字符串不行。解析這類變長部分的時候特別要注意包尾部的0,或者在緩沖區(qū)外部總保證存在一個0,或者保證包內(nèi)尾部總存在一個結(jié)尾0,總之最后一個string要保證有一個合法的0結(jié)束,當(dāng)然可能涉及到一些數(shù)值型到string型的轉(zhuǎn)換可能會導(dǎo)致效率下降,1的缺點在于只有一個層次。如果將內(nèi)容看作key1\0value1\0key2\0value2\0…可解決無序問題,但終歸只有一個層次,不方便表示樹形數(shù)據(jù)。

            方法2的效率介于13之間,2由于描述很簡潔,解析也是比較快的,比1好在可以解析任意層數(shù)據(jù),嵌套N層都無所謂,閱讀也很方便,解析的時候如果原始緩沖不釋放可讓字符串不復(fù)制直接記錄在原始緩沖中的指針,這樣可進一步提高解析效率。QQ種菜的通訊協(xié)議就是json格式的,閱讀很方便,解析效率也可以,總的效率適中。

            方法3的解析效率是最低的,好在xml描述性也比較強,解析代碼也很多,跟上層應(yīng)用交互的時候也比較方便,作為一個支持變長的選擇也是可行的,不過如果特別在意效率的情況下避免使用,xml的解析效率比 2低了近一個數(shù)量級,比1可能低近2個數(shù)量級。

             

            當(dāng)然自定義包還有更多格式選擇,標(biāo)準(zhǔn)協(xié)議也有很多如im 里面常見的xmppgoogleprotocol buffers等,還有json的一些擴展協(xié)議,如bjson等,如果只是處理一般的網(wǎng)游數(shù)據(jù)可能用不上這么復(fù)雜的協(xié)議,用上面提到的定長struct+1 or 2 or 3基本可以解決所有協(xié)議需求。也見到一些朋友自定義類型信息描述格式,個人覺得或許沒有必要,特別是json如此流行的情況下再自己定義似乎有重復(fù)發(fā)明輪子的嫌疑,當(dāng)然具體情況具體對待,一切以滿足需求為目標(biāo)。

            Posted on 2010-10-03 14:15 袁斌 閱讀(328) 評論(0)  編輯 收藏 引用

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


            996久久国产精品线观看| 一本色道久久88综合日韩精品| 亚洲日本va中文字幕久久| 久久久久免费看成人影片| 久久A级毛片免费观看| 91精品国产91久久| 精产国品久久一二三产区区别 | 精品多毛少妇人妻AV免费久久| 精品久久人妻av中文字幕| 国产精品美女久久久久av爽| 奇米影视7777久久精品人人爽| 国内精品久久久久伊人av| 欧美日韩精品久久免费| 久久综合中文字幕| 亚洲人成网亚洲欧洲无码久久| 99久久精品国产综合一区| 色婷婷久久综合中文久久蜜桃av| 午夜精品久久影院蜜桃| 亚洲国产精久久久久久久| 久久精品人成免费| 奇米影视7777久久精品| 伊人热热久久原色播放www| 精品99久久aaa一级毛片| 久久国产精品99久久久久久老狼| 伊人色综合久久天天网| 亚洲日本久久久午夜精品| 久久99热这里只有精品国产| 久久久久久久综合日本亚洲| 久久精品无码专区免费青青| 久久午夜伦鲁片免费无码| 精品无码久久久久国产动漫3d| 色偷偷91久久综合噜噜噜噜| 久久久综合香蕉尹人综合网| 久久久无码精品午夜| 少妇被又大又粗又爽毛片久久黑人| 久久www免费人成精品香蕉| 99久久国产综合精品成人影院| 久久夜色精品国产亚洲| 国产日韩久久免费影院| 久久影视国产亚洲| 麻豆av久久av盛宴av|