php autoload 性能,PHP__autoload()方法真的影响性能吗?_PHP教程

介绍

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

最终发现__autoload方法在性能方面的影响不是很大的。有的网友说不用__autoload(),带来的维护成本比性能成本高无数倍(比较赞同)。

环境

PHP:5.3.9 ——以fastcgi模式启动

Nginx:1.1.12

eaccelerator:0.9.6.1

截图:

376f992a5c26fd5eac68b70e005e49ac.png

启动界面:

c60f1a1f905a352a8386b296cf7c2736.png

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

142Z22593-2.png

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

366da2e1ff67b43504d0d1b9aa2c9d5d.png

测试:带着eAccelerator缓存进行测试

测试代码:经过__autoload加载

142Z220N-4.png

图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()

142Z234I-5.png

图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倍多。

摘自 川山甲

www.bkjia.comtrueTechArticle介绍 对于php性能问题,议论最多的就是__autoload()方法,很多人提到这个方法非常影响性能。还有人说opcode也能影响到__autoload()方法,所以针…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值