欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP __autoload()方法真的影响性能吗?

程序员文章站 2023-12-05 14:38:40
介绍 对于php性能问题,议论最多的就是__autoload()方法,很多人提到这个方法非常影响性能。还有人说opcode也能影响到__autoload()方法,所以针对这...
介绍

对于php性能问题,议论最多的就是__autoload()方法,很多人提到这个方法非常影响性能。还有人说opcode也能影响到__autoload()方法,所以针对这两点我做了个测试。
最终发现__autoload方法在性能方面的影响不是很大的。

环境

php:5.3.9 ——以fastcgi模式启动
nginx:1.1.12
eaccelerator:0.9.6.1

 
最终发现__autoload方法在性能方面的影响不是很大的。

 环境
 
 php:5.3.9 ——以fastcgi模式启动
 nginx:1.1.12
 eaccelerator:
 
截图:

PHP __autoload()方法真的影响性能吗?

 启动界面:

PHP __autoload()方法真的影响性能吗?

 eaccelerator(在php.ini文件中)配置情况:

PHP __autoload()方法真的影响性能吗?

  文件结构:(每一个test文件都是6000多行代码的文件)

PHP __autoload()方法真的影响性能吗?

 测试:带着eaccelerator缓存进行测试
 
测试代码:经过__autoload加载

PHP __autoload()方法真的影响性能吗?

 

       图1

我在浏览器里通过刷新得到的结果分别如下:
total time:0.10401391983032
total time:0.10252094268799
total time:0.095267057418823
total time:0.10013008117676
total time:0.096842050552368
total time:0.097998142242432
total time:0.10348510742188
total time:0.096648931503296
 
测试:不经过__autoload()

PHP __autoload()方法真的影响性能吗?

                         图2

测试结果——通过刷浏览器
total time:0.10309100151062
total time:0.10285210609436
total time:0.10154414176941
total time:0.097845792770386
total time:0.099545001983643
total time:0.10166597366333
 
最终看到的结果:autoload方法没有出现明显的性能下降
 
 测试:取消eaccelerator缓存进行测试
 
 图1的测试结果
total time:0.24992394447327
total time:0.25681900978088
total time:0.25327301025391
total time:0.22580695152283
total time:0.22656512260437
total time:0.22530484199524
total time:0.23080611228943
 
 图2的测试结果
total time:0.23054909706116
total time:0.22633790969849
total time:0.23442888259888
total time:0.2350070476532
total time:0.22897601127625
total time:0.23207712173462

 __autoload()方法在性能上还是没有明显的影响。

 总结
 
通过上面的两组实验得出:
1>__autoload方法没有明显的性能损失。所以大家不要介于使用__autoload方法。
2>opcode对代码的影响是比较大的,明显使用opcode的时候,php代码执行速度提高了将近2倍多。