专注WEB开发 分享经验,沉淀知识

PHP数组foreach、for、list-each-while遍历的对比

 作者:chenxing  时间:2018-05-06 02:21  评论:

但这并不意味着,我们都得用foreach处理数组,还得结合具体的才应用场景,每一种遍历方式都有各自的特点。当然各场景都适用的情况,优先想现在foreach,实力摆在这,比较foreach就是专门为遍历数组和对象设计的

foreach,for,list-each-while是PHP数组遍历常见的三种方式。

写了一段测试代码,单纯从遍历的角度看看这三者的性能。


$arr = range(0,100000);
$arrLen = count($arr);

$m0 = memory_get_usage();

//foreach
$start1 = microtime(true);
foreach ($arr as $val) {
    $temp[] = $val;
}
$m1 = memory_get_usage();
$end1 = microtime(true);
echo 'foreach耗时:',$end1 - $start1,'<br>';
echo '当前内存消耗:', $m1-$m0,'<br>';

//for
$start2 = microtime(true);
for($i=0; $i<$arrLen; $i++) {
    $temp2[] = $arr[$i];
}
$m2 = memory_get_usage();
$end2 = microtime(true);
echo 'for耗时:',$end2 - $start2,'<br>';
echo '当前内存消耗:',$m2-$m1, '<br>';

//list-each-while
reset($arr);
$start3 = microtime(true);
while(list($k,$v) = each($arr)){
    $temp3[] = $v;
}
$m3 = memory_get_usage();
$end3 = microtime(true);
echo 'list-each-while耗时:',$end3-$start3,'<br>';
echo '当前内存消耗:',$m3-$m2;

效果对比图:

foreach性能图

从图上看不管是从运行角度还是内存消耗来看,foreach在这三者中表现都是非常出色的。

但这并不意味着,我们都得用foreach处理数组,还得结合具体的应用场景,每一种遍历方式都有各自的特点。当然各场景都适用的情况,优先选择foreach,实力摆在这,毕竟foreach就是专门为遍历数组和对象设计的。

注意:foreach循环之后,$arr指针会被移出边界。foreach在遍历前有自动reset的功能,而list-each-while并没有,所有需要遍历前显示的reset让指针回到初始位置

除特别注明外,本站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/133.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

聊聊国产化

 2024-08-24 15:56  97

内网穿透工具frp配置详情

 2024-07-18 22:30  192

mac在终端复制出现乱码00~ *** 01~

 2024-07-16 20:38  43

php html生成图片

 2024-07-08 20:25  82

scp命令使用说明

 2024-07-06 12:14  113

如何在当前目录打开终端

 2024-07-04 14:54  84

 最新评论

 tradeOff: 08月30日 10:19
在某些领域国产化是一个迫不得已的事儿
来源: 聊聊国产化
 sue: 07月03日 10:24
可以
来源: 微信小程序如何获取单个input值
 流年: 07月02日 11:31
不错的尝试
来源: 博客系统如何用markdown编辑器发布文章
 诚心: 09月29日 23:01
学到了
来源: 如何一次性推送百万级别的消息
 Nick: 04月14日 12:26
网上的资料还是太老,都只是取一个元素,解决了一大难题
来源: redis set集合取出一组数据并删除
 skywalker: 11月03日 18:21
简洁明了
来源: mysql 获取某个日期的前一天或后一天