PHP应用程序的性能优化

发表于:2007-09-07来源:作者:点击数: 标签:
使用 PHP 编程的最大好处是学习这种编程语言非常容易以及其丰富的库。即使对需要使用的函数不是十分了解,我们也能够猜测出如何完成一个特定的任务。 尽管PHP非常简单易学,但我们仍然需要花费一点时间来学习PHP的一些编程技巧,尤其是与性能和内存占用相关
  使用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表目指的是自测试开始到这一特定的调用之前代码运行的总的时间。下面我们来看看下一个数组的输出:

  (未完)
<

原文转自:http://www.ltesting.net