Php 进行简单性能测试的更好方法

Php 进行简单性能测试的更好方法,php,benchmarking,performance-testing,microbenchmark,Php,Benchmarking,Performance Testing,Microbenchmark,在比较操作性能时,我通常会这样做测试: <?php $w = 'world'; $start1 = microtime(true); for($i=0;$i<10000;$i++) echo 'Hello ' . $w . '!'; $end1 = microtime(true); $start2 = microtime(true); for($i=0;$i<10000;$i++) echo "Hello $w!"; $end2 = microtime(tru

在比较操作性能时,我通常会这样做测试:

<?php
$w = 'world';
$start1 = microtime(true);
for($i=0;$i<10000;$i++)
    echo 'Hello ' . $w . '!';
$end1 = microtime(true);

$start2 = microtime(true);
for($i=0;$i<10000;$i++)
    echo "Hello $w!";
$end2 = microtime(true);

$start3 = microtime(true);
for($i=0;$i<10000;$i++)
    echo 'Hello ' + $w + '!';
$end3 = microtime(true);

echo "\n\n\n";
echo 'Concatination: ' . ($end1 - $start1) . "\nInline Var: " . ($end2 - $start2) . "\nAddition Operator: " . ($end3 - $start3);

正如您在每次运行时所看到的,可能会有非常不同的结果。

试试xdebug,它可以在运行时分析代码,生成跟踪文件。然后,可以通过wincachegrind/kcachegrind或类似程序运行此命令,以向您提供有关执行过程的详细信息、花费的时间等

Zend平台还包括一个分析器(如果您有可用的话)。我不记得免费的Zend Debugger和/或Zend Server Community Edition是否也包含探查器,但如果可以的话,它是另一个评测代码的选项


就个人而言,我更喜欢xdebug。

试试xdebug,它可以在运行时分析代码,生成跟踪文件。然后,可以通过wincachegrind/kcachegrind或类似程序运行此命令,以向您提供有关执行过程的详细信息、花费的时间等

Zend平台还包括一个分析器(如果您有可用的话)。我不记得免费的Zend Debugger和/或Zend Server Community Edition是否也包含探查器,但如果可以的话,它是另一个评测代码的选项


就个人而言,我更喜欢xdebug。

您选择的字符串连接方法与应用程序的性能几乎无关。当您试图从字符串连接中挤出几纳秒的执行时间时,您可能有一个O(n^3)嵌套循环,或者某个运行了8秒的未索引查询。还有,你忘了第四张表格:echo'Hello',$w';您选择的字符串连接方法与应用程序的性能几乎无关。当您试图从字符串连接中挤出几纳秒的执行时间时,您可能有一个O(n^3)嵌套循环,或者某个运行了8秒的未索引查询。还有,你忘了第四张表格:echo'Hello',$w';
Concatination: 0.057300090789795
Inline Var: 0.092978954315186
Addition Operator: 0.090532064437866

Concatination: 0.10458517074585
Inline Var: 0.075299978256226
Addition Operator: 0.039528131484985

Concatination: 0.063031911849976
Inline Var: 0.07781195640564
Addition Operator: 0.022316932678223

Concatination: 0.079019069671631
Inline Var: 0.030484914779663
Addition Operator: 0.096056938171387

Concatination: 0.077842950820923
Inline Var: 0.052779912948608
Addition Operator: 0.037421941757202

Concatination: 0.084203004837036
Inline Var: 0.013757944107056
Addition Operator: 0.074331045150757

Concatination: 0.027930021286011
Inline Var: 0.05648398399353
Addition Operator: 0.049610137939453

Concatination: 0.041821956634521
Inline Var: 0.047034978866577
Addition Operator: 0.062538862228394

Concatination: 0.0071420669555664
Inline Var: 0.066315889358521
Addition Operator: 0.004756927490234

Concatination: 0.088988065719604
Inline Var: 0.022722959518433
Addition Operator: 0.06276798248291