PHP文件缓存效率测试

来源:互联网 发布:工业数据采集器modbus 编辑:程序博客网 时间:2024/05/22 07:06
PHP文件缓存内容保存格式主要有三种:

            1.变量 var_export 格式化成PHP正常的赋值书写格式,用的时候直接include文件

            2.变量 serialize 序列化之后保存,用的时候反序列化

            3,变量 json_encode格式化之后保存,用的时候json_decode

        一直以来,我都以为第一种效率最高,因为那是PHP脚本解释器解析PHP脚本的格式,原生的,应该最快,至少读取缓存的效率应该是最高的,可是今天做了个测试,令我大跌眼镜!原来 serialize序列化效率才是最高的,不论是读还是写!

            下面是用来测试的PHP代码:

 

view plaincopy to clipboardprint?
  1. ";  
  2.     file_put_contents("data/in.php",$file);  
  3.     //include("data/in.php");  
  4. }  
  5. echo "include写:".(microtime(1)-$st)."<br> ";  
  6. $st = microtime(1);  
  7. for ($i=0;$i<1000;$i++){  
  8.     /* 
  9.     $file = var_export($_SERVER,1); 
  10.     $file = ""; 
  11.     file_put_contents("data/in.php",$file); 
  12.     */  
  13.     include("data/in.php");  
  14. }  
  15. echo "include读:".(microtime(1)-$st)."<br> ";  
  16.   
  17. $st = microtime(1);  
  18. for ($i=0;$i<1000;$i++){  
  19.     $file = file_put_contents("data/se.php",serialize($_SERVER));  
  20.     //$file = file_get_contents("data/se.php");  
  21.     //$file = unserialize($file);  
  22. }  
  23. echo "serialize写:".(microtime(1)-$st)."<br> ";  
  24. $st = microtime(1);  
  25. for ($i=0;$i<1000;$i++){  
  26.     //$file = file_put_contents("data/se.php",serialize($_SERVER));  
  27.     $file = file_get_contents("data/se.php");  
  28.     $file = unserialize($file);  
  29. }  
  30. echo "serialize读:".(microtime(1)-$st)."<br> ";  
  31.   
  32. $st = microtime(1);  
  33. for ($i=0;$i<1000;$i++){  
  34.     $file = file_put_contents("data/js.php",json_encode($_SERVER));  
  35.     //$file = file_get_contents("data/js.php");  
  36.     //$file = json_decode($file);  
  37. }  
  38. echo "json写:".(microtime(1)-$st)."<br> ";  
  39. $st = microtime(1);  
  40. for ($i=0;$i<1000;$i++){  
  41.     //$file = file_put_contents("data/js.php",json_encode($_SERVER));  
  42.     $file = file_get_contents("data/js.php");  
  43.     $file = json_decode($file);  
  44. }  
  45. echo "json读:".(microtime(1)-$st)."<br> ";  
  46. ?>  
"; file_put_contents("data/in.php",$file); //include("data/in.php");}echo "include写:".(microtime(1)-$st)." ";$st = microtime(1);for ($i=0;$i<1000;$i++){ /* $file = var_export($_SERVER,1); $file = ""; file_put_contents("data/in.php",$file); */ include("data/in.php");}echo "include读:".(microtime(1)-$st)." ";$st = microtime(1);for ($i=0;$i<1000;$i++){ $file = file_put_contents("data/se.php",serialize($_SERVER)); //$file = file_get_contents("data/se.php"); //$file = unserialize($file);}echo "serialize写:".(microtime(1)-$st)." ";$st = microtime(1);for ($i=0;$i<1000;$i++){ //$file = file_put_contents("data/se.php",serialize($_SERVER)); $file = file_get_contents("data/se.php"); $file = unserialize($file);}echo "serialize读:".(microtime(1)-$st)." ";$st = microtime(1);for ($i=0;$i<1000;$i++){ $file = file_put_contents("data/js.php",json_encode($_SERVER)); //$file = file_get_contents("data/js.php"); //$file = json_decode($file);}echo "json写:".(microtime(1)-$st)." ";$st = microtime(1);for ($i=0;$i<1000;$i++){ //$file = file_put_contents("data/js.php",json_encode($_SERVER)); $file = file_get_contents("data/js.php"); $file = json_decode($file);}echo "json读:".(microtime(1)-$st)." ";?>
结果太神奇了!
include写:0.559882879257include读:0.185745000839serialize写:0.255033969879serialize读:0.0853068828583json写:0.284864902496json读:0.145938873291
 
序列化是最快,无论读或写,都是第一种的效率的两倍,json比序列化效率稍低,表现还可以!
如果撇开文件读写所耗费的时间,他们的效率差别可能会更大!

include那个,虽然是PHP脚本赋值的格式,但是也是要分析解析文本,PHP脚本解释器需要动用整个解释器分析PHP脚本,而序列化不需要,只用启用序列化文本分析就行了,所以效率更高。