深入探讨array_map、foreach、for循环处理数组的效率

来源:互联网 发布:xp系统cpu优化工具 编辑:程序博客网 时间:2024/06/08 02:39
<?php
    header('content-type:text/html;charset=utf-8');
    //生命一个计算脚本运行时间的类
    class Timer{
        private $startTime = 0; //保存脚本开始执行时的时间(以微秒的形式保存)
        private $stopTime = 0; //保存脚本结束执行时的时间(以微秒的形式保存)


        //在脚本开始处调用获取脚本开始时间的微秒值
        function start(){
            $this->startTime = microtime(true); //将获取的时间赋值给成员属性$startTime
        }


        //脚本结束处嗲用脚本结束的时间微秒值
        function stop(){
            $this->stopTime = microtime(true); //将获取的时间赋给成员属性$stopTime
        }


        //返回同一脚本中两次获取时间的差值
        function spent(){
            return $this->stopTime - $this->startTime;
        }
    }


    $timer= new Timer();
    $array = range(1, 100000);


    $timer->start(); //在脚本文件开始执行时调用这个方法
    //每个数组的元素都加1
    //方法一:array_map
    $result = array_map(function($val){
        return $val+1;
    }, $array);
    $timer->stop(); //在脚本文件结束处调用这个方法


    echo "运用array_map处理数组时用了<b>".$timer->spent()."</b>微秒<br>";




    //方法二:
    foreach ($array as $key => &$value) {
        $value += 1;
    }
    $timer->stop(); //在脚本文件结束处调用这个方法
    
    echo "运用foreach处理数组时用了<b>".$timer->spent()."</b>微秒<br>";


    //方法三:
    for($i = 0;$i < count($array);$i++){
        $array[$i] += 1;
    }
    // echo "<pre>";
    // print_r($array);
    // echo "</pre>";
    $timer->stop(); //在脚本文件结束处调用这个方法


    echo "运用for处理数组时用了<b>".$timer->spent()."</b>微秒<br>";


    结果:


从中发现,array_map的速度最快,很多PHP框架中都使用它来循环处理函数,但是这并不能说array_map的效率是最高的,这跟PHP的版本、循环部分的业务逻辑有关,相对来说array_map的时间比较稳定,如果只是遍历展示数组,foreach应该是最快的,还有foreach只是个函数结果,不是个函数。

个人理解观点,希望大家批评指正!


?>
阅读全文
0 0
原创粉丝点击