php json_decode 效率,浅析PHP中json_encode、json_decode与serialize、unserialize的性能测试...

5fb9de1e218d6135816d446e1bde6386.png

今天偶然在想,如果用PHP写一个类似BDB的基于文件的Key-Value小型数据库用于存储非结构化的记录型数据,不知道效率会如何?

于是便联想到PHP中的对象怎么样序列化存储性价比最高呢?接着想到了之前同事推荐的JSON编码和解码函数。

据他所说,json_encode和json_decode比内置的serialize和unserialize函数要高效。

于是我决定动手实验,证实一下同事所说的情况是否属实。

实验分别在PHP 5.2.13和PHP 5.3.2环境下进行。

用同一个变量,分别用以上方式进行编码或解码10000次,并得出每个函数执行10000次所需的时间。

以下是PHP 5.2.13环境其中一次测试结果:

代码如下:json : 190

serialize : 257

json_encode : 0.08364200592041

json_decode : 0.18004894256592

serialize : 0.063642024993896

unserialize : 0.086990833282471

DONE.

以下是PHP 5.3.2环境其中一次测试结果:

代码如下:json : 190

serialize : 257

json_encode : 0.062805891036987

json_decode : 0.14239192008972

serialize : 0.048481941223145

unserialize : 0.05927300453186

DONE.

这次实验得到的结论是:

json_encode和json_decode的效率并没有比serialize和unserialize的效率高,在反序列化的时候性能相差两倍左右,PHP 5.3执行效率比PHP 5.2略有提升。

代码如下:<?php

$target = array (

'name' => '全能头盔',

'quality' => 'Blue',

'ti_id' => 21302,

'is_bind' => 1,

'demand_conditions' =>

array (

'HeroLevel' => 1,

),

'quality_attr_sign' =>

array (

'HeroStrength' => 8,

'HeroAgility' => 8,

'HeroIntelligence' => 8,

),

);

$json = json_encode($target);

$seri = serialize($target);

echo "json :\t\t" . strlen($json) . "\r\n";

echo "serialize :\t" . strlen($seri) . "\r\n\r\n";

$stime = microtime(true);

for ($i = 0; $i < 10000; $i ++)

{

json_encode($target);

}

$etime = microtime(true);

echo "json_encode :\t" . ($etime - $stime) . "\r\n";

//----------------------------------

$stime = microtime(true);

for ($i = 0; $i < 10000; $i ++)

{

json_decode($json);

}

$etime = microtime(true);

echo "json_decode :\t" . ($etime - $stime) . "\r\n\r\n";

//----------------------------------

$stime = microtime(true);

for ($i = 0; $i < 10000; $i ++)

{

serialize($target);

}

$etime = microtime(true);

echo "serialize :\t" . ($etime - $stime) . "\r\n";

//----------------------------------

$stime = microtime(true);

for ($i = 0; $i < 10000; $i ++)

{

unserialize($seri);

}

$etime = microtime(true);

echo "unserialize :\t" . ($etime - $stime) . "\r\n\r\n";

echo 'DONE.';

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值