php serialize json_encode 序列化性能测试

环境 php7_64 win7 命令行运行

<?php
//生成数组
$stime = microtime(true);
$a = array();
for($i=1;$i<3000000;$i++){
    $key = $i*2+$i ;
    $a[$key]=array();
    for($j=0;$j<4;$j++){
        $a[$key][$j]=rand(1,100000000);
    }
}
$etime = microtime(true);
echo iconv('UTF-8', 'GB2312//IGNORE',"生成数据耗时 :" . ($etime - $stime) . "\r\n" );

$stime = microtime(true);
$json = json_encode($a);
$etime = microtime(true);
echo iconv('UTF-8', 'GB2312//IGNORE',"json文本长度 :" . strlen($json) . "\r\n" );
echo iconv('UTF-8', 'GB2312//IGNORE',"数组转json耗时 :" . ($etime - $stime) . "\r\n" );

$stime = microtime(true);
$serialize = serialize($a);
$etime = microtime(true);
echo iconv('UTF-8', 'GB2312//IGNORE',"php自带 数组转文本 文本长度 :" . strlen($serialize) . "\r\n" );
echo iconv('UTF-8', 'GB2312//IGNORE',"php自带 数组转文本 耗时 :" . ($etime - $stime) . "\r\n" );


$stime = microtime(true);
$a = json_decode($json);
$etime = microtime(true);
echo iconv('UTF-8', 'GB2312//IGNORE',"json 文本转数组 耗时 :" . ($etime - $stime) . "\r\n" );

$stime = microtime(true);
$a = unserialize($serialize);
$etime = microtime(true);
echo iconv('UTF-8', 'GB2312//IGNORE',"php自带 文本转数组 耗时 :" . ($etime - $stime) . "\r\n" );

结果

D:\phpchina\phpchina\fengxiMac>D:\wapm\php-7\php -f ..\cesi.php
生成数据耗时 :4.7972741127014
json文本长度 :142294685
数组转json耗时 :2.7271559238434
php自带 数组转文本 文本长度 :226294668
php自带 数组转文本 耗时 :6.0113439559937
json 文本转数组 耗时 :15.242871999741
php自带 文本转数组 耗时 :7.3504211902618



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值