php msgpack 性能,php implode/explode, serialize, json, msgpack 性能对比

php implode/explode, serialize, json, msgpack 性能对比由于implode/explode不适合使用复杂的结构,因此常用的为serialize,json,msgpack三种。而三种比较,运

php implode/explode, serialize, json, msgpack 性能对比

首先使用implode, serialize, json_encode, msgpack_pack创建四个文本文件,用于测试。

创建代码如下:

$arr = array(

'content1' => '一二三四五六七八九十',

'content2' => '一二三四五六七八九十',

'content3' => '一二三四五六七八九十'

);

echo file_put_contents('implode.txt', implode(',',$arr), true).'
';

echo file_put_contents('serialize.txt', serialize($arr), true).'
';

echo file_put_contents('json.txt', json_encode($arr), true).'
';

echo file_put_contents('msgpack.txt', msgpack_pack($arr), true);

?>

创建后生成

implode.txt    92字节

serialize.txt   165字节

json.txt          223字节

msgpack.txt  121字节

生成的字符串大小排序如下 implode < msgpack_pack < serialize < json_encode

如果数组简单,则json_encode有可能比serialize小

例如:

$arr = array('一','二','三','四','五','六','七','八','九','十');serialize   为147字节

json_encode 为91字节

比较 implode, serialize, json_encode, msgpack_pack 性能

$arr = array(

'content1' => '一二三四五六七八九十',

'content2' => '一二三四五六七八九十',

'content3' => '一二三四五六七八九十'

);

$start = microtime(true);

$i = 1000000;

while($i>0){

// 分别测试运行时间及内存使用情况

$tmp = implode(',',$arr);

// $tmp = serialize($arr);

// $tmp = json_encode($arr);

// $tmp = msgpack_pack($arr);

$i--;

}

$end = microtime(true);

echo 'run time:'.($end-$start).'s
';

echo 'memory usage:'.(memory_get_usage()/1024).'KB';

?>

implode

1.3225722312927s 628.50KB

serialize

2.0553789138794s 628.32KB

json_encode 2.5058920383453s 628.34KB

msgpack_pack 1.6431028842926s 628.24KB

结果:内存使用情况差不多,运行时间implode < msgpack_pack < serialize < json_encode

比较 explode, unserialize, json_decode, msgpack_unpack 性能

$data = file_get_contents('implode.txt');

//$data = file_get_contents('serialize.txt');

//$data = file_get_contents('json.txt');

//$data = file_get_contents('msgpack.txt');

$start = microtime(true);

$i = 1000000;

while($i>0){

$tmp = explode(',',$data);

//$tmp = unserialize($data);

//$tmp = json_decode($data, true);

//$tmp = msgpack_unpack($data);

$i--;

}

$end = microtime(true);

echo 'run time:'.($end-$start).'s
';

echo 'memory usage:'.(memory_get_usage()/1024).'KB';

?>

explode

1.7446749210358s 628.74KB

unserialize

2.1386790275574s 628.67KB

json_decode

5.2423169612885s 628.84KB

msgpack_unpack 2.2290098667145s 628.63KB

结果:内存使用情况差不多,运行时间 explode < serialize < msgpack_unpack < json_decode

总结,由于implode/explode不适合使用复杂的结构,因此常用的为serialize,json,msgpack三种。

而三种比较,运行速度,,内存占用,空间占用最优为msgpack, 其次是serialize,最后是json。

如有条件,建议使用msgpack序列化处理数据。

关于msgpack 可以查看我之前写的文章:《MessagePack 序列化格式》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
/home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/v1/object.hpp:664:34: error: ‘void* memcpy(void*, const void*, size_t)’ copying an object of non-trivial type ‘struct msgpack::v2::object’ from an array of ‘const msgpack_object’ {aka ‘const struct msgpack_object’} [-Werror=class-memaccess] std::memcpy(&o, &v, sizeof(v)); ^ In file included from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/object_fwd.hpp:17, from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/v1/adaptor/adaptor_base_decl.hpp:14, from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/adaptor/adaptor_base_decl.hpp:13, from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/adaptor/adaptor_base.hpp:13, from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/v1/object_decl.hpp:16, from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/object_decl.hpp:14, from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/object.hpp:13, from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack.hpp:10, from /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/example/cpp03/stream.cpp:10: /home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master/include/msgpack/v2/object_fwd.hpp:23:8: note: ‘struct msgpack::v2::object’ declared here struct object : v1::object { ^~~~~~ cc1plus: all warnings being treated as errors make[2]: *** [example/cpp03/CMakeFiles/stream.dir/build.make:63:example/cpp03/CMakeFiles/stream.dir/stream.cpp.o] 错误 1 make[2]: 离开目录“/home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master” make[1]: *** [CMakeFiles/Makefile2:415:example/cpp03/CMakeFiles/stream.dir/all] 错误 2 make[1]: 离开目录“/home/AQTJClient/AQTJAuditClient/depends/msgpack-c-master”
07-20

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值