使用PHP编程的最大好处是学习这种编程语言非常容易以及其丰富的库。即使对需要使用的函数不是十分了解,我们也能够猜测出如何完成一个特定的任务。 尽管PHP非常简单易学,但我们仍然需要花费一点时间来学习PHP的一些编程技巧,尤其是与性能和内存占用相关的技巧。在PHP中,有许多小技巧能够使我们减少内存的占用,并提高应用程序的性能。在本篇文章中,我们将对PHP应用程序的分析、如何改变脚本代码以及比较优化前后的各种参数值进行简要的介绍。 通过在程序中设置计时的程序,并反复执行这些代码,我们可以获得有关程序执行速度的一组数据,这些数据可以可以用来发现程序中的瓶颈,以及如何进行优化,提高应用程序的性能。 也许读者曾经听说过PEAR库吧。我们将使用PEAR库创建在分析时需要使用的例子,这也是对现有的代码进行分析的最简单的方法,它使我们无需使用商用产品就能对代码进行分析。 我们要使用的库的名字是PEAR::Benchmark,它对于对代码进行分析和性能测试非常有用。这个库提供一个名字为Benchmark_Timer()的类,能够记录一个函数调用和下一个函数调用之间的时间。在对代码的性能进行测试时,我们可以得到一个详细的脚本执行结果,它非常简单,如下所示: include_once("Benchmark/Timer.php"); $bench = new Benchmark_Timer; $bench->start(); $bench->setMarker('Start of the script'); // 现在处于睡眠状态几分钟 sleep(5); $bench->stop(); // 从计时器中获得分析信息 print_r($bench->getProfiling()); ?> 上面代码执行后的输出如下所示: Array ( [0] => Array ( [name] => Start [time] => 1013214253.05751200 [diff] => - [total] => 0 ) [1] => Array ( [name] => Start of the script [time] => 1013214253.05761100 [diff] => 9.8943710327148E-05 [total] => 9.8943710327148E-05 ) [2] => Array ( [name] => Stop [time] => 1013214258.04920700 [diff] => 4.9915959835052 [total] => 4.9916949272156 ) ) 上面的数字似乎是一组杂乱无章的数字,但如果程序的规模更大,这些数字就十分地有用了。 也许广大读者也能猜测到,数组的第一个表目是实际调用Benchmark_Timer()类的方法,例如 $bench->start()、$bench->setMarker()和$bench->stop(),与这些表目有关的数字是相当简单的,现在我们来仔细地研究这些数字: [0] => Array ( [name] => Start [time] => 1013214253.05751200 [diff] => - [total] => 0 ) time表目指的是何时对Benchmark_Timer()的start()方法调用的UNIX的timestamp,diff表目表示这次调用和上次调用之间的时间间隔,由于这里没有上一次,因此显示出了一个破折号,total表目指的是自测试开始到这一特定的调用之前代码运行的总的时间。下面我们来看看下一个数组的输出: