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

今天偶然在想,如果用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环境其中一次测试结果:

代码如下:

  1. json : 190
  2. serialize : 257
  3. json_encode : 0.08364200592041
  4. json_decode : 0.18004894256592
  5. serialize : 0.063642024993896
  6. unserialize : 0.086990833282471
  7. DONE.

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

代码如下:

  1. json : 190
  2. serialize : 257
  3. json_encode : 0.062805891036987
  4. json_decode : 0.14239192008972
  5. serialize : 0.048481941223145
  6. unserialize : 0.05927300453186
  7. DONE.

这次实验得到的结论是:

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

代码如下:

  1. <?php
  2. $target = array (
  3. 'name' => '全能头盔',
  4. 'quality' => 'Blue',
  5. 'ti_id' => 21302,
  6. 'is_bind' => 1,
  7. 'demand_conditions' =>
  8. array (
  9. 'HeroLevel' => 1,
  10. ),
  11. 'quality_attr_sign' =>
  12. array (
  13. 'HeroStrength' => 8,
  14. 'HeroAgility' => 8,
  15. 'HeroIntelligence' => 8,
  16. ),
  17. );
  18. $json = json_encode($target);
  19. $seri = serialize($target);
  20. echo "json :\t\t" . strlen($json) . "\r\n";
  21. echo "serialize :\t" . strlen($seri) . "\r\n\r\n";
  22. $stime = microtime(true);
  23. for ($i = 0; $i < 10000; $i ++)
  24. {
  25. json_encode($target);
  26. }
  27. $etime = microtime(true);
  28. echo "json_encode :\t" . ($etime - $stime) . "\r\n";
  29. //----------------------------------
  30. $stime = microtime(true);
  31. for ($i = 0; $i < 10000; $i ++)
  32. {
  33. json_decode($json);
  34. }
  35. $etime = microtime(true);
  36. echo "json_decode :\t" . ($etime - $stime) . "\r\n\r\n";
  37. //----------------------------------
  38. $stime = microtime(true);
  39. for ($i = 0; $i < 10000; $i ++)
  40. {
  41. serialize($target);
  42. }
  43. $etime = microtime(true);
  44. echo "serialize :\t" . ($etime - $stime) . "\r\n";
  45. //----------------------------------
  46. $stime = microtime(true);
  47. for ($i = 0; $i < 10000; $i ++)
  48. {
  49. unserialize($seri);
  50. }
  51. $etime = microtime(true);
  52. echo "unserialize :\t" . ($etime - $stime) . "\r\n\r\n";
  53. echo 'DONE.';
  54. ?>