青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

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

msgpack[C++]使用筆記 和 msgpack/cPickle性能對比

轉(zhuǎn)載自:http://blog.csdn.net/xiarendeniao/article/details/6801338

python版本msgpack安裝:

wget http://pypi.python.org/packages/source/m/msgpack-python/msgpack-python-0.1.9.tar.gz

python2.x setup.py install --prefix=/usr/local/similarlib/


python版本的msgpack灰常好用,速度上比python內(nèi)置的pickle和cpickle都要快一些,C++版本的使用比較麻煩,下面是本人學(xué)習(xí)時(shí)的一個(gè)demo,解析python-msgpack dump的一個(gè)復(fù)雜字典

  1. #include <msgpack.hpp>  
  2.   
  3. #include <fstream>  
  4. #include <iostream>  
  5. using namespace std;  
  6.   
  7. template <class T>  
  8. void msgunpack(const char* binary_file, T& t, char* buff, uint32_t max){  
  9.     msgpack::unpacked msg;  
  10.     ifstream tf_file(binary_file,ios::in|ios::binary|ios::ate);  
  11.     uint32_t size = tf_file.tellg();  
  12.     tf_file.seekg(0, ios::beg);  
  13.     tf_file.read(buff, size);  
  14.     tf_file.close();  
  15.     msgpack::unpack(&msg, buff, size);  
  16.     msg.get().convert(&t);  
  17. }  
  18.   
  19.   
  20. typedef map<uint32_t, uint32_t> WordsMap;  
  21. typedef map<uint32_t, WordsMap> FieldsMap;  
  22. typedef map<uint64_t, FieldsMap> DocsMap;  
  23.   
  24. int main(int argc, char** argv)  
  25. {  
  26.     uint32_t MAX_BUFF = 1024*1024*100; //100MB  
  27.     char* BUFF = new char[MAX_BUFF];  
  28.   
  29.     DocsMap docsMap;  
  30.     msgpack::unpacked msg;  
  31.     msgunpack("/data/wikidoc/tf_dict_for_nodes/1-1000", docsMap, BUFF, MAX_BUFF);  
  32.     //        msg.get().convert(&docsMap);  
  33.     cout << docsMap.size() << endl;  
  34.         delete[] BUFF;  
  35. }  



參考: http://wiki.msgpack.org/pages/viewpage.action?pageId=1081387#QuickStartforC%2B%2B-ImplementationStatus


下面是本人自己封裝的一個(gè)msgpack接口頭文件mymsgpack.h

  1.  #ifndef MY_MSGPACK_H  
  2.   
  3. #ifndef MY_MSGPACK_H  
  4. #define MY_MSGPACK_H  
  5. #include <fstream>  
  6. #include <msgpack.hpp>  
  7. using namespace std;  
  8.   
  9. template <class T>  
  10. void load_from_file(const char* binary_file, T& t) {  
  11.         ifstream binaryFstream(binary_file,ios::in|ios::binary|ios::ate);  
  12.         uint32_t size = binaryFstream.tellg();  
  13.         char* buff = new char[size];  
  14.         binaryFstream.seekg(0, ios::beg);  
  15.         binaryFstream.read(buff, size);  
  16.         binaryFstream.close();  
  17.         msgpack::unpacked msg;  
  18.         msgpack::unpack(&msg, buff, size);  
  19.         msg.get().convert(&t);  
  20.         delete[] buff;  
  21. }  
  22.   
  23. template <class T>  
  24. void load_from_str(const char* binary_str, int len, T& t) {  
  25.         msgpack::unpacked msg;  
  26.         msgpack::unpack(&msg, binary_str, len);  
  27.         msg.get().convert(&t);  
  28. }  
  29.   
  30. template <class T>  
  31. void dump_to_file(T& t, const char* dump_file) {  
  32.     msgpack::sbuffer sbuf;  
  33.     msgpack::pack(sbuf, t);  
  34.     ofstream dumpFstream(dump_file, ios::out|ios::binary|ios::trunc);  
  35.     dumpFstream.write(sbuf.data(), sbuf.size());  
  36.     dumpFstream.close();  
  37. }  
  38.   
  39. template <class T>  
  40. void dump_to_str(T& t, char** dump_str, int& len) { //外部釋放*dump_str  
  41.     msgpack::sbuffer sbuf;  
  42.     msgpack::pack(sbuf, t);  
  43.     len = sbuf.size();  
  44.     *dump_str = (char*)malloc(sbuf.size());  
  45.     memcpy(*dump_str, sbuf.data(), sbuf.size());  
  46. }  
  47.   
  48. #endif  


 


msgpack編譯通過,鏈接不上的問題 undefined reference to `__sync_sub_and_fetch_4'

在x84_64機(jī)器上正常,在32bit機(jī)器上出現(xiàn)上述問題

[plain] view plaincopy
  1. [xudongsong@BigServerU-4 msgpack-0.5.7]$ cat /etc/issue  
  2. CentOS release 5.4 (Final)  
  3. Kernel \r on an \m  
  4.   
  5. [xudongsong@BigServerU-4 msgpack-0.5.7]$ file /sbin/init  
  6. /sbin/init: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), for GNU/Linux 2.6.9, dynamically linked (uses shared libs), for GNU/Linux 2.6.9, stripped  

./configure不報(bào)錯(cuò),但是查看config.log顯示有錯(cuò)誤,程序鏈接msgpack的庫時(shí)也報(bào)錯(cuò)

原因:gcc不能識別CPU體系,需要手動(dòng)指明

[plain] view plaincopy
  1. [xudongsong@BigServerU-4 msgpack-0.5.7]$ CFLAGS="-march=pentium -mtune=pentium" ./configure --prefix=/home/xudongsong/msgpack_static --enable-static=yes --enable-shared=no  

make, make install

[xudongsong@BigServerU-4 jobs]$ g++ job_calc_weight.cpp -o job_calc_weight -I/home/xudongsong/msgpack_static/include/ -L/home/xudongsong/msgpack_static/lib/ -lmsgpack

通過!

 


 

下面是msgpack和cPickle進(jìn)行性能pk的demo程序(不比較pickle,是因?yàn)樗萩Pickle更慢,《Python cook book》里面有說明):

[python] view plaincopy
  1. mport sys,time,msgpack,pickle,cPickle,random  
  2.   
  3. test_list = []  
  4. i = 0  
  5. while i<100000:  
  6.     test_list = random.randrange(1,100000)  
  7.     i += 1  
  8.   
  9. print "common len(serialize) = %s"%len(cPickle.dumps(test_list,0))  
  10. print "compress len(serialize) = %s"%len(cPickle.dumps(test_list,1))  
  11.   
  12. #------------------------------------------------------------------------  
  13. results = {}  
  14. time_start = time.time()  
  15. for i in range(1,1000000):  
  16.         results[i] = cPickle.dumps(test_list,1)  
  17. time_mid_1 = time.time()  
  18. print "cPickle dumps eats %s s"%str(time_mid_1-time_start)  
  19.   
  20. for i in range(1,1000000):  
  21.     cPickle.loads(results[i])  
  22. time_mid_2 = time.time()  
  23. print "cPickle loads eats %s s"%str(time_mid_2-time_mid_1)  
  24.   
  25. #------------------------------------------------------------------------  
  26. results = {}  
  27. time_start = time.time()  
  28. for i in range(1,1000000):  
  29.     results[i] = msgpack.dumps(test_list)  
  30. time_mid_1 = time.time()  
  31. print "msgpack pack eats %s s"%str(time_mid_1-time_start)  
  32.   
  33. for i in range(1,1000000):  
  34.     msgpack.loads(results[i])  
  35. time_mid_2 = time.time()  
  36. print "msgpack unpack eats %s s"%str(time_mid_2-time_mid_1)  

 

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            母乳一区在线观看| 在线观看日韩国产| 欧美一激情一区二区三区| 亚洲欧洲精品一区二区精品久久久 | 激情综合视频| 悠悠资源网亚洲青| 亚洲第一成人在线| 亚洲人人精品| 亚洲一级特黄| 午夜视频一区| 老司机免费视频一区二区| 欧美不卡三区| 亚洲精品一二三| 亚洲综合日韩在线| 久久色在线播放| 欧美日韩国产黄| 国产精品久久毛片a| 久久综合亚州| 亚洲国产欧美日韩| 亚洲午夜一级| 久久久久久夜| 欧美日韩成人综合在线一区二区| 欧美日韩综合视频| 国产综合精品一区| 一区二区三区高清在线| 久久国产精品免费一区| 亚洲第一网站| 欧美一区二区三区在线观看| 欧美国产精品一区| 国产丝袜一区二区三区| 日韩亚洲欧美一区二区三区| 欧美在线视频一区| 日韩视频一区二区在线观看| 欧美一区二区三区免费视| 欧美成人综合一区| 国产综合色产在线精品| 正在播放欧美视频| 美女免费视频一区| 午夜精品久久久久久久久久久 | 亚洲人成在线观看网站高清| 午夜欧美理论片| 欧美日韩精品一区视频| 亚洲大片av| 久久精品国产亚洲精品| 一区二区免费在线观看| 欧美va天堂| 亚洲电影免费观看高清完整版| 西西人体一区二区| 9久re热视频在线精品| 欧美国产一区二区| 亚洲福利久久| 农夫在线精品视频免费观看| 欧美一区二区三区喷汁尤物| 国产精品色网| 亚洲女同性videos| 99视频精品在线| 欧美日本亚洲韩国国产| 亚洲乱码久久| 亚洲欧洲精品成人久久奇米网| 久久一区二区三区国产精品| 极品少妇一区二区| 久久这里有精品15一区二区三区| 性欧美激情精品| 免费美女久久99| 欧美一区二区性| 国产精品一区二区久久国产| 亚洲性xxxx| 一二三区精品福利视频| 欧美日韩一区二区三区四区在线观看| 亚洲人精品午夜在线观看| 亚洲国产精品一区| 免费在线看成人av| 日韩视频精品在线观看| 亚洲天堂网站在线观看视频| 91久久精品一区二区三区| 欧美刺激性大交免费视频| 亚洲美女视频| 9久草视频在线视频精品| 国产精品久久久久久久久久尿 | 99精品视频免费在线观看| 91久久中文字幕| 欧美视频成人| 久久精品国产精品 | 久久一区二区三区国产精品 | 亚洲自拍偷拍视频| 亚洲尤物在线| 韩国亚洲精品| 亚洲国产经典视频| 国产精品成人一区二区艾草| 欧美一级艳片视频免费观看| 久久久久久久久岛国免费| 亚洲精品久久久久久一区二区| 日韩视频一区二区三区在线播放 | 99精品视频一区| 亚洲一区三区在线观看| 伊人久久婷婷色综合98网| 亚洲国产欧美另类丝袜| 国产精品一区视频| 亚洲电影欧美电影有声小说| 国产精品久久影院| 欧美粗暴jizz性欧美20| 国产精品成人一区二区网站软件 | 亚洲专区一二三| 永久免费精品影视网站| 在线亚洲一区观看| 在线观看国产日韩| 亚洲永久在线| 99精品视频一区| 久久蜜桃资源一区二区老牛 | 亚洲深夜av| 亚洲欧洲精品一区二区三区 | 久久综合伊人77777| 亚洲专区国产精品| 男女激情视频一区| 国产午夜精品久久久| 久久亚洲影音av资源网| 欧美日韩一区在线视频| 久久综合久久综合九色| 国产精品国产三级国产普通话三级 | 久热精品视频在线观看| 亚洲免费在线播放| 欧美另类变人与禽xxxxx| 欧美日韩高清在线观看| 久久久www成人免费无遮挡大片 | 亚洲第一福利在线观看| 国产午夜亚洲精品不卡| 一区二区欧美激情| 一区二区欧美国产| 欧美精品一区二区三区很污很色的| 久久午夜国产精品| 国产日韩专区在线| 亚洲欧美日韩直播| 欧美一区二区播放| 国产精品午夜久久| 亚洲欧美精品| 欧美一级视频精品观看| 国产精品色午夜在线观看| 亚洲视频精品| 午夜久久福利| 国产日韩高清一区二区三区在线| 亚洲一区二区成人| 久久爱www久久做| 国产欧美一区二区精品仙草咪| 一本一道久久综合狠狠老精东影业| 中国成人亚色综合网站| 开心色5月久久精品| 欧美成人嫩草网站| 亚洲精品韩国| 欧美日韩一二三区| 亚洲永久免费| 久久久青草婷婷精品综合日韩| 国产亚洲精品bv在线观看| 久久爱91午夜羞羞| 欧美jjzz| 亚洲特级毛片| 国产伦精品一区二区三区视频孕妇 | 亚洲国产精品久久久久婷婷老年| 久久精品中文| 亚洲高清在线精品| 在线一区免费观看| 国产欧美精品在线播放| 久久国产精品99国产精| 欧美激情精品久久久久久久变态| 亚洲国产日韩一区| 欧美日韩亚洲国产一区| 午夜精品一区二区三区在线播放| 久久人人爽爽爽人久久久| 国内视频精品| 欧美成人中文字幕在线| 亚洲精品国产精品乱码不99按摩| 欧美大片第1页| 亚洲免费综合| 久久―日本道色综合久久| 亚洲国产精品va| 国产精品劲爆视频| 久久这里有精品视频| 亚洲最黄网站| 免费中文字幕日韩欧美| 亚洲在线成人| 在线观看国产精品网站| 亚洲国产视频直播| 久久午夜电影| 亚洲片区在线| 性做久久久久久免费观看欧美| 国产婷婷97碰碰久久人人蜜臀| 欧美激情按摩| 欧美一级淫片播放口| 亚洲国产黄色| 久久高清福利视频| 亚洲网站视频福利| 尤物网精品视频| 国产精品丝袜白浆摸在线| 久久久精品国产99久久精品芒果| 亚洲人在线视频| 久久夜精品va视频免费观看| 亚洲一区二区三区四区五区午夜| 国一区二区在线观看| 欧美天堂亚洲电影院在线观看| 久久久亚洲人| 久久aⅴ乱码一区二区三区|