首页 > 解决方案 > 如何对代码进行基准测试以查看哪个运行得更快

问题描述

$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');

谁能告诉我在 php 文件的大型操作中哪个更快、更推荐并且占用更少的内存。我认为它的 DateInterval PID。有经验的开发者吗?

标签: phpdatetimedateinterval

解决方案


要对代码进行基准测试,您可以使用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 . "\n";

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 . "\n";

这输出:

modify: 0.039623975753784 
interval: 0.036103963851929

如您所见,在每次执行 10,000 次计算之后,DateInterval 是更快的代码。然而,这就是我所说的微优化!没有太大区别!

看到它在这里工作https://3v4l.org/pCecn


推荐阅读