PHP中json_encode、json_decode与serialize、unserialize的性能测试分析
程序员文章站
2024-01-14 20:21:40
于是便联想到php中的对象怎么样序列化存储性价比最高呢?接着想到了之前同事推荐的json编码和解码函数。 据他所说,json_encode和json_decode比内置的s...
于是便联想到php中的对象怎么样序列化存储性价比最高呢?接着想到了之前同事推荐的json编码和解码函数。
据他所说,json_encode和json_decode比内置的serialize和unserialize函数要高效。
于是我决定动手实验,证实一下同事所说的情况是否属实。
实验分别在php 5.2.13和php 5.3.2环境下进行。
用同一个变量,分别用以上方式进行编码或解码10000次,并得出每个函数执行10000次所需的时间。
以下是php 5.2.13环境其中一次测试结果:
json : 190
serialize : 257
json_encode : 0.08364200592041
json_decode : 0.18004894256592
serialize : 0.063642024993896
unserialize : 0.086990833282471
done.
以下是php 5.3.2环境其中一次测试结果:
json : 190
serialize : 257
json_encode : 0.062805891036987
json_decode : 0.14239192008972
serialize : 0.048481941223145
unserialize : 0.05927300453186
done.
这次实验得到的结论是:
json_encode和json_decode的效率并没有比serialize和unserialize的效率高,在反序列化的时候性能相差两倍左右,php 5.3执行效率比php 5.2略有提升。
以下是我用来做测试的代码:
<?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.';
?>
据他所说,json_encode和json_decode比内置的serialize和unserialize函数要高效。
于是我决定动手实验,证实一下同事所说的情况是否属实。
实验分别在php 5.2.13和php 5.3.2环境下进行。
用同一个变量,分别用以上方式进行编码或解码10000次,并得出每个函数执行10000次所需的时间。
以下是php 5.2.13环境其中一次测试结果:
复制代码 代码如下:
json : 190
serialize : 257
json_encode : 0.08364200592041
json_decode : 0.18004894256592
serialize : 0.063642024993896
unserialize : 0.086990833282471
done.
以下是php 5.3.2环境其中一次测试结果:
复制代码 代码如下:
json : 190
serialize : 257
json_encode : 0.062805891036987
json_decode : 0.14239192008972
serialize : 0.048481941223145
unserialize : 0.05927300453186
done.
这次实验得到的结论是:
json_encode和json_decode的效率并没有比serialize和unserialize的效率高,在反序列化的时候性能相差两倍左右,php 5.3执行效率比php 5.2略有提升。
以下是我用来做测试的代码:
复制代码 代码如下:
<?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.';
?>
上一篇: Win10全新Edge浏览器和IE11相比真的安全吗?
下一篇: 定位功能的实现(一)——基础配置
推荐阅读
-
PHP中json_encode、json_decode与serialize、unserialize的性能测试分析
-
php中serialize序列化与json性能测试的示例分析
-
php中serialize序列化与json性能测试的示例分析_php实例
-
PHP中json_encode、json_decode与serialize、unserialize的性能测试分析
-
php中serialize序列化与json性能测试的示例分析
-
php中serialize序列化与json性能测试的示例分析_PHP教程
-
php中serialize序列化与json性能测试的示例分析_php实例
-
php中serialize序列化与json性能测试的示例分析_PHP
-
php中serialize序列化与json性能测试的示例分析
-
php中serialize序列化与json性能测试的示例分析_PHP