php foreach 效率,php 各种遍历方式及效率测试 while foreach for 异同

先贴代码

include 'SortClass.php';

$i = 0;

$reward = [];

while($i < 100000){

$a = mt_rand(100,999);

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

$i++;

}

SortClass::consumeTime('启动计数');

$items = [];

foreach($reward as $v){

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

}

SortClass::consumeTime('foreach');

$items = [];

$items = array_map(function($v){

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

},$reward);

SortClass::consumeTime('array_map');

$items = [];

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

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

$i++;

}

SortClass::consumeTime('while');

$items = [];

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

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

}

SortClass::consumeTime('for');

$items = [];

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

SortClass::consumeTime('array_column');

-------------------

//打印时间方法

public static function consumeTime($remark = ''){

static $start , $end , $num = null;

$num++;

if(!$start){

$start = microtime(true);

return true;

}

$end = microtime(true);

var_dump("第 {$num} 次:- {$remark} - :" . bcsub($end,$start,4));

$start = microtime(true);

}

再贴结果 遍历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....  另外,单位是秒

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值