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

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            linux使用msgpack及測試

            轉載自:http://blog.csdn.net/sunny3106/article/details/7375907

            在網絡程序的開發中,免不了會涉及到服務器與客戶端之間的協議交互,由于客戶端與服務器端的平臺的差異性(有可能是windows,android,linux等等),以及網絡字節序等問題,通信包一般會做序列化與反序列化的處理,也就是通常說的打包解包工作。google的protobuf是一個很棒的東西,它不僅提供了多平臺的支持,而且直接支持從配置文件生成代碼。但是這么強大的功能,意味著它的代碼量以及編譯生成的庫文件等等都不會小,如果相對于手機游戲一兩M的安裝包來說,這個顯然有點太重量級了(ps:查了一下protobuf2.4.1的jar的包大小有400k左右),而且在手機游戲客戶端與服務器的交互過程中,很多時候基本的打包解包功能就足夠了。

            今天經同事推薦,查閱了一下msgpack相關的資料。msgpack提供快速的打包解包功能,官網上給出的圖號稱比protobuf快4倍,可以說相當高效了。最大的好處在與msgpack支持多語言,服務器端可以用C++,android客戶端可以用java,能滿足實際需求。

            在實際安裝msgpack的過程中,碰到了一點小問題,因為開發機器是32位機器,i686的,所以安裝完后跑一個簡單的sample時,c++編譯報錯,錯誤的表現為鏈接時報錯:undefined reference to `__sync_sub_and_fetch_4',后來參考了下面的博客,在configure時指定CFLAGS="-march=i686"解決,注意要make clean先。

            msgpack官網地址:http://msgpack.org/

            安裝過程中參考的博客地址:http://blog.csdn.net/xiarendeniao/article/details/6801338



            ====================================================================================

            ====================================================================================

            補上近期簡單的測試結果

            測試機器,cpu 4核 Dual-Core AMD Opteron(tm) Processor 2212,單核2GHz,1024KB cache, 內存4G。


            1. 簡單包測試

            1. struct ProtoHead  
            2. {  
            3.     uint16_t uCmd;      // 命令字  
            4.     uint16_t uBodyLen;  // 包體長度(打包之后的字符串長度)  
            5.     uint32_t uSeq;      //消息的序列號,唯一標識一個請求  
            6.     uint32_t uCrcVal;           // 對包體的crc32校驗值(如果校驗不正確,服務器會斷開連接)  
            7. };  
            8.   
            9. struct ProtoBody  
            10. {  
            11.     int num;  
            12.     std::string str;  
            13.     std::vector<uint64_t> uinlst;  
            14.     MSGPACK_DEFINE(num, str, uinlst);  
            15. };  

            測試中省略了包頭本地字節序與網絡字節序之間的轉化,只有包體做msgpack打包處理.

            vector數組中元素數量為16個,每次循環做一次打包與解包,并驗證前后數據是否一致,得到的測試結果如下:

            總耗時(s)

            循環次數

            平均每次耗時(ms)

            0.004691

            100

            0.04691

            0.044219

            1000

            0.044219

            0.435725

            10000

            0.043573

            4.473818

            100000

            0.044738

            總結:基本每次耗時0.045ms左右,每秒可以打包解包22k次,速度很理想。


            2. 復雜包測試(vector嵌套)

            1. struct test_node  
            2. {  
            3.     std::string str;  
            4.     std::vector<uint32_t> idlst;  
            5.   
            6.     test_node()  
            7.     {  
            8.         str = "it's a test node";  
            9.   
            10.         for (int i = 0; i++; i < 10)  
            11.         {  
            12.             idlst.push_back(i);  
            13.         }  
            14.     }  
            15.   
            16.     bool operator == (const test_node& node) const  
            17.     {  
            18.         if (node.str != str)  
            19.         {  
            20.             return false;  
            21.         }  
            22.   
            23.         if (node.idlst.size() != idlst.size())  
            24.         {  
            25.             return false;  
            26.         }  
            27.   
            28.         for (int i = 0; i < idlst.size(); i++)  
            29.         {  
            30.             if (idlst[i] != node.idlst[i])  
            31.             {  
            32.                 return false;  
            33.             }  
            34.         }  
            35.         return true;  
            36.     }  
            37.   
            38.     MSGPACK_DEFINE(str, idlst);  
            39. };  
            40.   
            41. struct ProtoBody  
            42. {  
            43.     int num;  
            44.     std::string str;  
            45.     std::vector<uint64_t> uinlst;  
            46.     std::vector<test_node> nodelst;  
            47.   
            48.     MSGPACK_DEFINE(num, str, uinlst, nodelst);  
            49. };  
            每個nodelst中插入16個node,每個node中的idlst插入16個id,同1中的測試方法,得到測試結果如下:

            總耗時(s)

            循環次數

            平均每次耗時(ms)

            0.025401

            100

            0.25401

            0.248396

            1000

            0.248396

            2.533385

            10000

            0.253339

            25.823562

            100000

            0.258236

            基本上每次打包解包一次要耗時0.25ms,每秒估算可以做4k次打包解包,速度還是不錯的。


            3. 加上crc校驗

            如果每個循環中,打包過程加上crc的計算,解包過程中加上crc校驗,得到測試結果如下:

            總耗時(s)

            循環次數

            平均每次耗時(ms)

            0.025900

            100

            0.25900

            0.260424

            1000

            0.260424

            2.649585

            10000

            0.264959

            26.855452

            100000

            0.268555

            基本上每次打包解包耗時0.26ms左右,與沒有crc差別不大;

            posted on 2014-05-29 09:16 楊粼波 閱讀(3720) 評論(0)  編輯 收藏 引用 所屬分類: C++

            久久久久女教师免费一区| 精品国产热久久久福利| 亚洲国产精品综合久久网络 | 中文字幕久久精品| 久久精品国产亚洲av水果派 | av无码久久久久不卡免费网站| 久久天天躁狠狠躁夜夜不卡| 欧美性大战久久久久久| 精品久久久久国产免费| 国产精品女同一区二区久久| 日韩亚洲欧美久久久www综合网| 996久久国产精品线观看| 99久久国产热无码精品免费| 97久久精品无码一区二区天美| 国产精品久久久久AV福利动漫| 国产成人精品免费久久久久| 99久久精品国产高清一区二区| 国产91久久精品一区二区| 久久精品国产一区| 久久本道综合久久伊人| 久久久人妻精品无码一区| 亚洲精品无码久久不卡| 亚洲伊人久久成综合人影院 | 污污内射久久一区二区欧美日韩 | 久久SE精品一区二区| 久久久一本精品99久久精品88| 久久久精品国产sm调教网站| 国产亚洲欧美成人久久片| 国内精品欧美久久精品| 久久午夜福利电影| 久久久久亚洲AV无码专区首JN| 久久九九精品99国产精品| 亚洲精品国产成人99久久| 看全色黄大色大片免费久久久| 亚洲国产另类久久久精品小说 | 一本久道久久综合狠狠爱| 精品久久久久久无码中文字幕一区| 狠狠色噜噜狠狠狠狠狠色综合久久| 国产精品成人无码久久久久久| 久久天天躁夜夜躁狠狠躁2022| 国内精品久久久人妻中文字幕|