php遍历的效率比较,php各种遍历方式及效率测试whileforeachfor异同

先贴代码

while($i < 1000){

$a = mt_rand(100,999);

$reward[] = ['id'=>$a, 'num'=>$a];

$i++;

}

$sort = new SortClass();

$sort->consumeTime('启动计数');

$items = [];

foreach($reward as $v){

$items[$v['id']] = [$v['id'],$v['num']];

}

$sort->consumeTime('foreach');

$items = [];

$items = array_map(function($v){

return [$v['id'] => [$v['id'],$v['num']]];

},$reward);

$sort->consumeTime('array_map');

$items = [];

while($i < sizeof($reward)){

$items[$reward[$i]['id']] = [$reward[$i]['id'],$reward[$i]['num']];

$i++;

}

$sort->consumeTime('while');

$items = [];

for($i = 0; $i < sizeof($reward); $i++){

$items[$reward[$i]['id']] = [$reward[$i]['id'],$reward[$i]['num']];

}

$sort->consumeTime('for');

$items = [];

$items = array_column($reward, null, 'id');

$sort->consumeTime('array_column');

再贴结果 遍历1000个元素时

aa7ca74ae0c958898efd3db81d637747.png

10000个

119fe5977fa4cc1f340b5dae6358cb74.png

10万个

63cf1c27874a2f1d5efc72ab99551408.png

测试环境 php7.2.5  nginx  win10

可以看出array_column效率最快,while次之,再然后foreach  array_map最差。

但是可能常规遍历基本不会超过几千次,几万或更大的话其实也不太适合php来执行。所以便利性来说个人觉得还是foreach比较方便,array_map的话非业务逻辑必要还是少用比较好。

em....  另外,单位是秒

文章来源: www.oschina.net,作者:曲文,版权归原作者所有,如需转载,请联系作者。

原文链接:https://my.oschina.net/u/3538113/blog/3107646

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值