smarty模板嵌套之include与fetch性能测试


Posted in PHP onDecember 05, 2010

方法一、使用在父模板中使用{include file="child.tpl"}直接将子模板包含进来

优点:

1、有利于模块的划分和模板的重用。

2、嵌套层次不多的时候,模板的结构清晰,一眼过去就知道这个模板的内容和结构。

3、只需要一个smarty实例就能做完所有的事情,减少系统资源的占用。

不足:

1、子模板中的变量可能与父模板的变量发生冲突

2、多重嵌套的时候,变量名冲突的几率增大,为所有的变量赋值的难度也加大。

3、子模板的可操控性差,例如不能通过设置$cache_id, $compile_id,来得到多个结果。

4、扩展性差。如果需要添加新的模板的时候需要修改模板,同时还需要修改程序。

方法二、通过$smarty->fetch()将子模板的数据当成变量assign到父模板中

优点:

1、同样有利于模块的划分,模板的重用

2、模板的结构同样清晰

3、子模板作为单独的对象,可操控性强

4、扩展性较好 

5、每个子模板都是单独的对象,不会出现变量名冲突的问题

不足:

1、如果子模板多的时候,需使用多个smarty实例来实现,PHP代码显得臃肿

2、占用较多的系统资源

3、......

在那个的时候,出于对性能的要求,以及在没有测试的情况下,想当然的认为include的性能一定就比fetch的性能要高,所有本人使用include这个方法,结果随着系统功能的不断的增加,感觉到越写越复杂,这有很大一部分原因是设计的问题,但是模板间的嵌套也是问题之一,于是回过头来考虑使用fetch这个方法。在重新做出决定之前对这个方法的性能做了测试,分别对单个模板的情况下和多个模板的情况进行测试

单个子模板测试:

有三个页面test1.php,test2.php,test3.php。这三个页面都输出同样的内容。test1.php的模板没有嵌套,test2.php的模板使用了一次include,test3.php使用fetch来实现子模板的嵌套。使用apache自带的ab测试访问各个页面所需要的平均时间(单位:ms)

第一次测试时,使用ab -n 10000 对以上三个页面进行10次,每次累计10000个访问,结果如下。

ab -n 10000 test1.php test2.php test3.php test2/test1 test3/test1
1 5.178 5.442 6.097 1.050984936 1.177481653
2 5.253 5.972 6.027 1.136874167 1.147344375
3 5.223 6.039 5.987 1.156232051 1.146276087
4 5.533 5.997 6.02 1.083860474 1.08801735
5 5.557 6.308 6.03 1.135144862 1.085117869
6 5.248 6.002 5.998 1.14367378 1.142911585
7 5.211 5.933 6.003 1.138553061 1.151986183
8 5.303 6.031 6.048 1.137280784 1.140486517
9 5.213 5.923 6.033 1.136197967 1.15729906
总计 47.719 53.647 54.243 1.124227247 1.136717031

第二次测试时,使用ab -n 100000 对以上三个页面进行1次,每次累计100000个访问,结果如下。

ab -n 100000 test1.php test2.php test3.php test2/test1 test3/test1
1 5.723 7.874 8.55 1.375851826 1.493971693

第一次测试的数据中,test1和test2的波动比较明显,test3则比较稳定,这个现象让我感到十分的奇怪。从平均数据来看,测试结果还是在预期之内的,test1的性能最好,test2比test1多耗费了12.42%的时间,test3比test1多耗费了13.67%的时间,但是test2和test3之间的差距并不大,仅仅只有1.3%左右的差别。

第二次测试的结果,三个页面的执行时间比为1:1.37:1.49,奇怪的是这次的波动更大。。。

多个子模板测试:

同样有三个页面test1.php,test2.php,test3.php。这三个页面都输出同样的内容。test1.php的模板没有嵌套,test2.php的模板使用了10次include嵌入了10个子模板,test3.php使用10次fetch嵌入了10个子模板。使用apache自带的ab测试访问各个页面所需要的平均时间(单位:ms)

因为时间的关系我只进行了一次ab -n 50000的测试,数据如下

ab -n 50000 test1.php test2.php test3.php test2/test1 test3/test1
1 5.68 6.054 6.028 1.06584507 1.061267606

 

虽然测试的方法和工具可能不是很好,但是通过这些数据的对比,在实际的应用中到底要采用哪种方法,我想大家应该心里有底了吧。

不足和错误之处还望指出,希望大家能多讨论多交流。

PHP 相关文章推荐
php在线生成ico文件的代码
Oct 09 PHP
php网站来路获取代码(针对搜索引擎)
Jun 08 PHP
destoon实现不同会员组公司名称显示不同的颜色的方法
Aug 22 PHP
PHP中使用curl入门教程
Jul 02 PHP
PHP结合Mysql数据库实现留言板功能
Mar 04 PHP
Linux系统中为php添加pcntl扩展
Aug 28 PHP
PHP构造二叉树算法示例
Jun 21 PHP
php使用curl模拟浏览器表单上传文件或者图片的方法
Nov 10 PHP
laravel 实现划分admin和home 模块分组
Oct 15 PHP
Laravel + Elasticsearch 实现中文搜索的方法
Feb 02 PHP
php 多进程编程父进程的阻塞与非阻塞实例分析
Feb 22 PHP
PHP时间类完整代码实例
Feb 26 PHP
php 学习资料零碎东西
Dec 04 #PHP
PHP访问MYSQL数据库封装类(附函数说明)
Dec 04 #PHP
PHP验证码类代码( 最新修改,完全定制化! )
Dec 02 #PHP
PHP项目开发中最常用的自定义函数整理
Dec 02 #PHP
PHP自动选择 连接本地还是远程数据库
Dec 02 #PHP
Mysql数据库操作类( 1127版,提供源码下载 )
Dec 02 #PHP
PHP分页函数代码(简单实用型)
Dec 02 #PHP
You might like
真正面向对象编程:PHP5.01发布
2006/10/09 PHP
PHP 导出数据到淘宝助手CSV的方法分享
2010/02/27 PHP
php实现按文件名搜索文件的远程文件查找器
2014/05/10 PHP
thinkphp如何获取客户端IP
2015/11/03 PHP
深入浅析Yii admin的权限控制
2016/08/31 PHP
php接口技术实例详解
2016/12/07 PHP
JS判断页面加载状态以及添加遮罩和缓冲动画的代码
2012/10/11 Javascript
js出生日期 年月日级联菜单示例代码
2014/01/10 Javascript
JavaScript中number转换成string介绍
2014/12/31 Javascript
jquery任意位置浮动固定层插件用法实例
2015/05/29 Javascript
使用smartupload组件实现jsp+jdbc上传下载文件实例解析
2017/01/05 Javascript
js实现从左向右滑动式轮播图效果
2017/07/07 Javascript
javascript基于牛顿迭代法实现求浮点数的平方根【递归原理】
2017/09/28 Javascript
浅谈Vue.js 组件中的v-on绑定自定义事件理解
2017/11/17 Javascript
单页面vue引入百度统计的使用方法示例详解
2018/10/13 Javascript
微信小程序 textarea 层级过高问题简单解决方案
2019/10/14 Javascript
vue-cli4.x创建企业级项目的方法步骤
2020/06/18 Javascript
[15:09]DOTA2国际邀请赛采访专栏:Loda
2013/08/06 DOTA
用Python编写一个简单的Lisp解释器的教程
2015/04/03 Python
详解Python中的__getitem__方法与slice对象的切片操作
2016/06/27 Python
Python三级目录展示的实现方法
2016/09/28 Python
python画双y轴图像的示例代码
2019/07/07 Python
python3+django2开发一个简单的人员管理系统过程详解
2019/07/23 Python
Python实现的爬取豆瓣电影信息功能案例
2019/09/15 Python
18个Python脚本可加速你的编码速度(提示和技巧)
2019/10/17 Python
tensorflow自定义激活函数实例
2020/02/04 Python
django 利用Q对象与F对象进行查询的实现
2020/05/15 Python
新西兰便宜隐形眼镜购买网站:QUICKLENS New Zealand
2019/03/02 全球购物
财务会计专业毕业生自荐信
2013/10/02 职场文书
大学四年个人自我小结
2014/03/05 职场文书
《荷花》教学反思
2014/04/16 职场文书
公司贷款承诺书
2014/05/30 职场文书
2015年十月一日放假通知
2015/08/18 职场文书
小学一年级语文教学反思
2016/03/03 职场文书
2016年清明节期间群众祭祀活动工作总结
2016/04/01 职场文书
2019财务毕业实习报告
2019/06/27 职场文书