如何高效优化PHP代码解析损耗

开发 后端
PHP代码解析损耗的优化目标是一个访问只运行一个php文件,并且这个文件里不包含任何与这个流程无关的代码。

程序员们在进行PHP代码编程中总会希望对自己的代码程序进行最优化的操作,使程序尽量的轻便简洁。我们在性能分析shopex性能的时候。#t#

发现用在PHP的语法解析上的损耗占了很大比重,如果用valgrind看他的C调用的话,就会发现大约50%的时间被用在lex&yacc上面。也就是由PHP代码转成opcode的部分。即PHP代码解析损耗。

这个方面PHP代码解析损耗的优化极限目标是: 一个访问只运行一个PHP文件,并且这个文件里不包含任何与这个流程无关的代码。

如何兼顾代码结构容易理解和性能是个挑战

我们的处理思路是,通过类似smarty的编译系统,将访问编译成一个个文件:因为shopex是mvc的结构,那么编译粒度就每个控制器的方法对应一个流程文件。

当控制器第一次调用时,通过一种方法监控流经的每个model-method,子过程等等,最后抽取剥离出来,加上公用的数据库连接函数,配置文件等等一起组合成一个单一的终极PHP文件。
至于缓存的更新基本就是版本的更新,每次升级的时候。touch一个cachestat文件的最后修改时间即可。

那么实现的挑战有两个:

* 一个叫model的函数化 (这样叫很酷,有点像虚的死神化) 。是弱化model层对象特性,让类退化为仅是函数的容器,减少继承,重载这些应用。
* 二是实现一个自己的编译引擎。

上面两条最新的shopex485已经走了很远了,商品和订单的函数都已经拆分了。第二个PHP代码解析损耗的解决办法是我们自己实现了一个叫tramsy的解析器( 翻转(smart)+y ),特点是把大量的插件改成了编译型。强化了编译插件的特性,增加了一种编译型modifier的插件类型。并且提出了变量预绑定的概念:

 

  1. {if $var=1}  
  2. yes  
  3. {elseif $var=2}  
  4. no  
  5. {else}  
  6. what?  
  7. {/if} 

 

如果是原生的smarty,生成的代码是:

 

  1. vars['var']==1){ ?> 
  2. yes  
  3. vars['var']==2){ ?> 
  4. no  
  5. what? 

 

如果在tramsy里,程序员预测var一定是1,并且有把握在其值改变的时候系统自动清除模板缓存,就可以把他设置为”预绑定变量”
那么最终生成的代码就是:

no

这个设计大约减少了一倍多的编译结果。性能提升了大约20%,极大的优化了PHP代码解析损耗。

责任编辑:曹凯 来源: shopex.cn
相关推荐

2009-02-20 11:05:58

PHP优化高效提速

2015-01-28 14:30:31

android代码

2009-11-27 13:24:20

PHP代码性能优化

2018-05-11 08:39:42

NAND闪存损耗均衡算法优化

2009-12-07 15:41:51

PHP图片加水印

2009-12-08 14:20:30

PHP CLI脚本

2011-06-01 16:56:57

2011-07-12 17:33:09

PHP

2010-01-05 13:54:32

Jquery Json

2022-09-06 07:00:35

CR代码

2009-12-03 11:11:57

PHP网站优化

2019-05-28 10:00:06

PHP代码前端

2009-11-26 10:32:57

PHP代码优化

2009-02-23 09:11:21

2011-03-24 13:09:11

数据库代码

2024-06-03 10:12:15

2012-06-18 15:18:32

JS

2009-07-31 14:50:16

电缆回波损耗

2009-12-02 13:07:27

PHP XMLRead

2009-12-02 10:49:59

PHP解析XML元素结
点赞
收藏

51CTO技术栈公众号