各种序列化库的体验

来源:互联网 发布:网络海外代购兼职 编辑:程序博客网 时间:2024/05/16 12:05

这里只用python来分析说明。

python自带的两个cPickle, marshal

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

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

import timeimport cPickleimport simplejsonimport marshalimport msgpackimport cjsontest_obj = ['abc', 123, {"abc":123}, ("abc", 123), 4.56]times = 100000st = time.clock()for x in xrange(times):    cPickle.loads(cPickle.dumps(test_obj))print 'cPickle process %s times used %s '%(times, time.clock()-st)st = time.clock()for x in xrange(times):    simplejson.loads(simplejson.dumps(test_obj))print 'simplejson process %s times used %s '%(times, time.clock()-st)st = time.clock()for x in xrange(times):    cjson.decode(cjson.encode(test_obj))print 'cjson process %s times used %s '%(times, time.clock()-st)st = time.clock()for x in xrange(times):    marshal.loads(marshal.dumps(test_obj))print 'marshal process %s times used %s '%(times, time.clock()-st)st = time.clock()for x in xrange(times):    msgpack.loads(msgpack.dumps(test_obj))print 'msgpack use loads/dumps process %s times used %s '%(times, time.clock()-st)st = time.clock()packer = msgpack.Packer()unpacker = msgpack.Unpacker()for x in xrange(times):    unpacker.feed(packer.pack(test_obj))    unpacker.unpack()print 'msgpack use Packer/Unpacker process %s times used %s '%(times, time.clock()-st)


我本机的运行结果:
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则只有数据信息,要小很多。 这是两种不同的设计哲学。今天太晚了,以后有空把这两种的使用和比较测试也写一下。

原创粉丝点击