dongxun2089 2018-05-25 09:43
浏览 28
已采纳

如何对代码进行基准测试以查看运行速度更快

$datetime = new DateTime('2013-01-29');
$datetime->modify('+1 day');
echo $datetime->format('Y-m-d H:i:s');

$datetime = new DateTime('2013-01-29');
$datetime->add(new DateInterval('P1D'));
echo $datetime->format('Y-m-d H:i:s');

Can anyone tell me which is faster, recommended and takes less memory in huge operations in php file. I think its DateInterval PID. Any experienced developer?

  • 写回答

2条回答 默认 最新

  • doujiaochan7317 2018-05-25 11:09
    关注

    To benchmark code, you can use microtime()

    http://php.net/manual/en/function.microtime.php

    <?php
    
    echo 'modify: ';
    $time = microtime(1);
    for ($x = 0; $x < 10000; $x++) {
        $datetime = new DateTime('2013-01-29');
        $datetime->modify('+1 day');
    }
    echo $datetime->format('Y-m-d H:i:s'); 
    $end = microtime(1);
    $time = $end - $time;
    echo $time . "
    ";
    
    echo 'interval: ';
    $time = microtime(1);
    for ($x = 0; $x < 10000; $x++) {
        $datetime = new DateTime('2013-01-29');
        $datetime->add(new DateInterval('P1D'));
    }
    $end = microtime(1);
    $time = $end - $time;
    echo $time . "
    ";
    

    This outputs :

    modify: 0.039623975753784 
    interval: 0.036103963851929
    

    As you can see, after performing the calculation 10,000 times on each, DateInterval is the faster code. However, this is what I would call a microoptimisation! There isn't much difference!

    See it working here https://3v4l.org/pCecn

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 BP神经网络控制倒立摆
  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算