PHP中json_encode、json_decode与serialize、unserialize的性能测试分析

  于是便联想到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.';

  ?>