各种序列化库的体验

这里只用python来分析说明。

python自带的两个cPickle, marshal

我用过或尝试过的包括simplejson, AMF, protoBuf, MessagePack

就这些来分析比较一下吧。


我本机的运行结果:
cPickle process 100000 times used 1.63 
simplejson process 100000 times used 2.45 
cjson process 100000 times used 0.91 
marshal process 100000 times used 0.28 
msgpack use loads/dumps process 100000 times used 1.17 
msgpack use Packer/Unpacker process 100000 times used 0.28 

可以看出marshal是很快的,但它有版本不兼容问题, simplejson比较慢,但好像有个cjson比cPickle还快, MessagePack使用loads/dumps速度和cPickle差不多, 使用pcker/unpacker则快很多,它号称比json快10倍,比protobuf快4倍,呵呵,不过我本地安装msgpack-idl --install python 一直没有成功,说没有gem包,就不能用来和protobuf进行比较了

剩下两种AMF, ProtoBuf则真正在rpc里用的比较多,上面几种都有不同的缺点, 比如cross language就不够好, 而AMF和protobuf这方面则作的不错, AMF出来的东西长度要长一些,因为它包括类型信息,而protobuf则只有数据信息,要小很多。 这是两种不同的设计哲学。今天太晚了,以后有空把这两种的使用和比较测试也写一下。

posted @ 2011-07-21 01:07  酱油哥  阅读(511)  评论(0)    收藏  举报