PHP中json_encode、json_decode與serialize、unserialize的性能測(cè)試分析
更新時(shí)間:2010年06月09日 10:46:27 作者:
今天偶然在想,如果用PHP寫一個(gè)類似BDB的基于文件的Key-Value小型數(shù)據(jù)庫(kù)用于存儲(chǔ)非結(jié)構(gòu)化的記錄型數(shù)據(jù),不知道效率會(huì)如何?
于是便聯(lián)想到PHP中的對(duì)象怎么樣序列化存儲(chǔ)性價(jià)比最高呢?接著想到了之前同事推薦的JSON編碼和解碼函數(shù)。
據(jù)他所說,json_encode和json_decode比內(nèi)置的serialize和unserialize函數(shù)要高效。
于是我決定動(dòng)手實(shí)驗(yàn),證實(shí)一下同事所說的情況是否屬實(shí)。
實(shí)驗(yàn)分別在PHP 5.2.13和PHP 5.3.2環(huán)境下進(jìn)行。
用同一個(gè)變量,分別用以上方式進(jìn)行編碼或解碼10000次,并得出每個(gè)函數(shù)執(zhí)行10000次所需的時(shí)間。
以下是PHP 5.2.13環(huán)境其中一次測(cè)試結(jié)果:
json : 190
serialize : 257
json_encode : 0.08364200592041
json_decode : 0.18004894256592
serialize : 0.063642024993896
unserialize : 0.086990833282471
DONE.
以下是PHP 5.3.2環(huán)境其中一次測(cè)試結(jié)果:
json : 190
serialize : 257
json_encode : 0.062805891036987
json_decode : 0.14239192008972
serialize : 0.048481941223145
unserialize : 0.05927300453186
DONE.
這次實(shí)驗(yàn)得到的結(jié)論是:
json_encode和json_decode的效率并沒有比serialize和unserialize的效率高,在反序列化的時(shí)候性能相差兩倍左右,PHP 5.3執(zhí)行效率比PHP 5.2略有提升。
以下是我用來做測(cè)試的代碼:
<?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.';
?>
據(jù)他所說,json_encode和json_decode比內(nèi)置的serialize和unserialize函數(shù)要高效。
于是我決定動(dòng)手實(shí)驗(yàn),證實(shí)一下同事所說的情況是否屬實(shí)。
實(shí)驗(yàn)分別在PHP 5.2.13和PHP 5.3.2環(huán)境下進(jìn)行。
用同一個(gè)變量,分別用以上方式進(jìn)行編碼或解碼10000次,并得出每個(gè)函數(shù)執(zhí)行10000次所需的時(shí)間。
以下是PHP 5.2.13環(huán)境其中一次測(cè)試結(jié)果:
復(fù)制代碼 代碼如下:
json : 190
serialize : 257
json_encode : 0.08364200592041
json_decode : 0.18004894256592
serialize : 0.063642024993896
unserialize : 0.086990833282471
DONE.
以下是PHP 5.3.2環(huán)境其中一次測(cè)試結(jié)果:
復(fù)制代碼 代碼如下:
json : 190
serialize : 257
json_encode : 0.062805891036987
json_decode : 0.14239192008972
serialize : 0.048481941223145
unserialize : 0.05927300453186
DONE.
這次實(shí)驗(yàn)得到的結(jié)論是:
json_encode和json_decode的效率并沒有比serialize和unserialize的效率高,在反序列化的時(shí)候性能相差兩倍左右,PHP 5.3執(zhí)行效率比PHP 5.2略有提升。
以下是我用來做測(cè)試的代碼:
復(fù)制代碼 代碼如下:
<?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.';
?>
您可能感興趣的文章:
- 詳解php中serialize()和unserialize()函數(shù)
- php序列化函數(shù)serialize() 和 unserialize() 與原生函數(shù)對(duì)比
- php中magic_quotes_gpc對(duì)unserialize的影響分析
- php函數(shù)serialize()與unserialize()用法實(shí)例
- php中unserialize返回false的解決方法
- 淺談php函數(shù)serialize()與unserialize()的使用方法
- 淺談php serialize()與unserialize()的用法
- 非常好用的兩個(gè)PHP函數(shù) serialize()和unserialize()
- php serialize()與unserialize() 不完全研究
相關(guān)文章
對(duì)text數(shù)據(jù)類型不支持代碼頁轉(zhuǎn)換 從: 1252 到: 936
錯(cuò)誤的提示同樣是不能從text的轉(zhuǎn)換問題:這主要是由于數(shù)據(jù)庫(kù)在設(shè)計(jì)的時(shí)候的數(shù)據(jù)類型存在Text——而我們采用的是中文操作系統(tǒng)。檢查數(shù)據(jù)庫(kù)的腳本,修改Text為ntext。支持unicode。2011-04-04
PHP實(shí)現(xiàn)動(dòng)態(tài)刪除XML數(shù)據(jù)的方法示例
這篇文章主要介紹了PHP實(shí)現(xiàn)動(dòng)態(tài)刪除XML數(shù)據(jù)的方法,在前面介紹的Message_XML類基礎(chǔ)上進(jìn)行改進(jìn),增加了xml刪除功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2018-03-03
PHP中strncmp()函數(shù)比較兩個(gè)字符串前2個(gè)字符是否相等的方法
這篇文章主要介紹了PHP中strncmp()函數(shù)比較兩個(gè)字符串前2個(gè)字符是否相等的方法,實(shí)例分析了strncmp()函數(shù)的功能,參數(shù)用法與使用技巧,需要的朋友可以參考下2016-01-01
php實(shí)現(xiàn)批量刪除掛馬文件及批量替換頁面內(nèi)容完整實(shí)例
這篇文章主要介紹了php實(shí)現(xiàn)批量刪除掛馬文件及批量替換頁面內(nèi)容的方法,涉及php文件與目錄的遍歷、查找以及字符串與數(shù)組的遍歷與替換操作相關(guān)技巧,適用于utf-8編碼環(huán)境,需要的朋友可以參考下2016-07-07

