PHP文件缓存效率测试

PHP文件缓存内容保存格式主要有三种:

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

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

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

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

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

view plaincopy to clipboardprint?
$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)." "; 
$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脚本,而序列化不需要,只用启用序列化文本分析就行了,所以效率更高。

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fzzwake/archive/2008/07/26/2714975.aspx

你可能感兴趣的:(PHP)