详解php中implode explode serialize json msgpack性能对比

作者:傲雪星枫 时间:2023-09-03 18:00:19 

测试方法

首先使用implode, serialize, json_encode, msgpack_pack创建四个文本文件,用于测试。

创建代码如下:


<?php
$arr = array(
   'content1' => '一二三四五六七八九十',
   'content2' => '一二三四五六七八九十',
   'content3' => '一二三四五六七八九十'
);
echo file_put_contents('implode.txt', implode(',',$arr), true).'<br>';
echo file_put_contents('serialize.txt', serialize($arr), true).'<br>';
echo file_put_contents('json.txt', json_encode($arr), true).'<br>';
echo file_put_contents('msgpack.txt', msgpack_pack($arr), true);
?>

创建后生成

implode.txt    92字节
serialize.txt   165字节
json.txt          223字节
msgpack.txt  121字节

生成的字符串大小排序如下 implode < msgpack_pack < serialize < json_encode

如果数组简单,则json_encode有可能比serialize小

例如:


$arr = array('一','二','三','四','五','六','七','八','九','十');

serialize   为147字节

json_encode 为91字节

比较 implode, serialize, json_encode, msgpack_pack 性能


<?php
$arr = array(
   'content1' => '一二三四五六七八九十',
   'content2' => '一二三四五六七八九十',
   'content3' => '一二三四五六七八九十'
);

$start = microtime(true);
$i = 1000000;
while($i>0){
   // 分别测试运行时间及内存使用情况
   $tmp = implode(',',$arr);
   // $tmp = serialize($arr);
   // $tmp = json_encode($arr);
   // $tmp = msgpack_pack($arr);
   $i--;
}
$end = microtime(true);
echo 'run time:'.($end-$start).'s<br>';
echo 'memory usage:'.(memory_get_usage()/1024).'KB';
?>

implode       1.3225722312927s    628.50KB

serialize     2.0553789138794s    628.32KB

json_encode   2.5058920383453s    628.34KB

结果:内存使用情况差不多,运行时间 implode < msgpack_pack < serialize < json_encode

比较 explode, unserialize, json_decode, msgpack_unpack 性能


<?php
$data = file_get_contents('implode.txt');
//$data = file_get_contents('serialize.txt');
//$data = file_get_contents('json.txt');
//$data = file_get_contents('msgpack.txt');

$start = microtime(true);
$i = 1000000;
while($i>0){
   $tmp = explode(',',$data);
   //$tmp = unserialize($data);
   //$tmp = json_decode($data, true);
   //$tmp = msgpack_unpack($data);
   $i--;
}
$end = microtime(true);
echo 'run time:'.($end-$start).'s<br>';
echo 'memory usage:'.(memory_get_usage()/1024).'KB';
?>

explode         1.7446749210358s    628.74KB

unserialize     2.1386790275574s    628.67KB

json_decode     5.2423169612885s    628.84KB

结果:内存使用情况差不多,运行时间  explode < serialize < msgpack_unpack < json_decode

来源:https://blog.csdn.net/fdipzone/article/details/43679337

标签:php,性能,serialize,msgpack,pack
0
投稿

猜你喜欢

  • python下载图片实现方法(超简单)

    2021-12-21 02:17:07
  • python中numpy 常用操作总结

    2021-01-10 05:01:57
  • 详解MySQL主键唯一键重复插入解决方法

    2024-01-20 16:41:22
  • 利用Python实现斐波那契数列的方法实例

    2022-11-07 11:20:14
  • 基于python实现删除指定文件类型

    2022-02-16 06:19:48
  • SQL Server优化50法汇总

    2024-01-24 11:11:37
  • ORACLE 10g 安装教程[图文]

    2023-07-15 07:07:27
  • css+js实现部分区域高亮可编辑遮罩层

    2024-02-25 08:49:23
  • mysql5.7.20第一次登录失败的快速解决方法

    2024-01-19 16:57:36
  • PHP:微信小程序 微信支付服务端集成实例详解及源码下载

    2023-11-14 13:37:55
  • 算法系列15天速成 第四天 五大经典查找【上】

    2023-12-18 01:20:38
  • 深度剖析使用python抓取网页正文的源码

    2022-09-29 15:53:39
  • php获取当前时间的毫秒数的方法

    2023-06-28 06:43:37
  • 使用Go HTTP客户端打造高性能服务

    2024-05-05 09:28:29
  • golang 调用c语言动态库方式实现

    2024-05-22 17:51:02
  • Python爬虫工具requests-html使用解析

    2021-10-23 02:20:27
  • 这些有问题的细节设计

    2009-04-20 12:47:00
  • python爬虫爬取股票的北上资金持仓数据

    2023-11-18 20:44:56
  • 变态输入框——再谈校验包容性(一)

    2009-10-10 13:23:00
  • go swagger生成接口文档使用教程

    2023-10-20 12:31:35
  • asp之家 网络编程 m.aspxhome.com