各种序列化库的体验

这里只用python来分析说明。

python自带的两个cPickle, marshal

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

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

import time
import cPickle
import simplejson
import marshal
import msgpack
import cjson


test_obj = ['abc', 123, {"abc":123}, ("abc", 123), 4.56]
times = 100000


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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值