PHP文件缓存内容保存格式主要有三种:
1.变量 var_export 格式化成PHP正常的赋值书写格式,用的时候直接include文件
2.变量 serialize 序列化之后保存,用的时候反序列化
3,变量 json_encode格式化之后保存,用的时候json_decode
一直以来,我都以为第一种效率最高,因为那是PHP脚本解释器解析PHP脚本的格式,原生的,应该最快,至少读取缓存的效率应该是 最高的,可是今天做了个测试,令我大跌眼镜!原来 serialize序列化效率才是最高的,不论是读还是写!
下面是用来测试的PHP代码:
$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.559882879257
include读:0.185745000839
serialize写:0.255033969879
serialize读:0.0853068828583
json写:0.284864902496
json读:0.145938873291
序列化是最快,无论读或写,都是第一种的效率的两倍,json比序列化效率稍低,表现还可以!
如果撇开文件读写所耗费的时间,他们的效率差别可能会更大!
include那个,虽然是PHP脚本赋值的格式,但是也是要分析解析文本,PHP脚本解释器需要动用整个解释器分析PHP脚本,而序列化不需要, 只用启用序列化文本分析就行了,所以效率更高。