【译】Smarty vs Twig: 性能对比

#1 jake

Smarty是PHP语言里面最经典的模板引擎,如果你曾经开发过PHP程序,那么或多或少都有使用过它。Smarty在2010年发布了第三版,Smarty 3用当下最新的PHP5进行了重构。它保留了原有的语法并加入了一些更现代的特性。

Twig是来自Symfony开发者,Twig作者将其定位成一个快速及功能强大的现代模板引擎。Twig有着许多与Smarty 3相似的特性,但为了提高性能而稍微有些不同。

现在我们来将两者进行一下性能对比测试:

测试
我们准备了较复杂的模板以便可以明显看出程序执行的时间,以下是我们的代码:
相同的功能,看起来Smarty实现更简单些:
$data = json_decode(file_get_contents('data.json'), true); 
require('smarty/Smarty.class.php');
$smarty = new Smarty();
$smarty->compile_check = false;
$start = microtime(true);
$smarty->assign($data);
$smarty->fetch('demo.tpl');
echo microtime(true)-$start;
Twig更复杂些:
$data = json_decode(file_get_contents('data.json'), true); 
require('twig/Autoloader.php');
Twig_Autoloader::register();
$loader = new Twig_Loader_Filesystem('templates');
$twig = new Twig_Environment($loader, array(
    'cache' => 'templates_c',
    'autoescape' => false,
    'auto_reload' => false,
));
$start = microtime(true);
$template = $twig->loadTemplate('demo.tpl');
$template->render($data);
echo microtime(true)-$start;
两个程序都做了同样的配置:关闭二次编译、不显示页面,只留下执行时间的显示。

从变量中获取值
从变量中获取值是比较常用的操作,在较复杂的模板开发中或许会用上几百次。我们或许会认为该操作的执行速度不需要依赖于模板,但不是的,模板引擎会在模板中用一些数据结构来存储变量的值,所以获取变量值的操作需要更简单和快速的性能。下面我们将生成一个带有10000个值的模板以比较性能。

Smarty:
{$var0} {$var1} {$var2} {$var3} {$var4} ...

Twig:
< var0 > < var1 > < var2 > < var3 > < var4 > ...

Result:
[table=98%]
[tr][td] [/td][td]Compiling[/td][td]Execution[/td][/tr]
[tr][td]Smarty 3.1.1[/td][td]16.320 seconds[/td][td]0.058 seconds[/td][/tr]
[tr][td]Twig 1.2.0[/td][td]9.757 seconds[/td][td]0.083 seconds[/td][/tr]
[/table]上面的表格演示了多次连续测试的平均值。我们可以看到程序已经编译生成了1万个变量的模板,Smarty在编译的时候是远远落后于Twig。不过编译仅仅是第一次访问的时候执行,之后会一直使用编译后的页面,所以编译后的页面执行速度才是更重要的。编译后的执行时间,Smarty是比Twig快速了30%左右,

使用多次foreach来测试
一般开发中模板经常用到foreach,这里我们用了1000个带有十个元素的数组,来测试一下两个模板引擎的foreach性能。

Smarty:
{foreach $array as $item} 
{$item.id} {$item.title} {$item.var1} {$item.var2} {$item.var3} {$item.var4} {$item.var5} {$item.var6} {$item.var5} {$item.var6}
{/foreach}
Twig:
{% for item in array %} 
< item.id > < item.title > < item.var1 > < item.var2 > < item.var3 > < item.var4 > < item.var5 > < item.var6 > < item.var5 > < item.var6 >
{% endfor %}
Result:
[table=98%]
[tr][td] [/td][td]Compiling[/td][td]Execution[/td][/tr]
[tr][td]Smarty 3.1.1[/td][td]0.065 seconds[/td][td]0.009 seconds[/td][/tr]
[tr][td]Twig 1.2.0[/td][td]0.131 seconds[/td][td]0.082 seconds[/td][/tr]
[/table]这里有个令人惊讶的情况:编译后的Smarty模板比Twig执行快近10倍以上。与此同时,就算是编译+执行一起计算,Smarty还是会比Twig快。我们可以推测模板编译器而言,Smarty初始化比Twig要快许多。Smarty在上个测试中执行中稍微慢些,但在小型模板中几乎无法察觉。

继承
模板中继承是一个很方便的机制。或者可以认为继承是在使用已经过严格测试的模板引擎吧。让我们来看看当Smarty和Twig执行继承的时候会有多少性能上的负载。
我们建立了一个父模板,它拥有500个块(blocks)的子模板,每个子模板都继承于上一个子模板,同时子模板中都有静态的数据提供给父模板来调用。我们将通过模板引擎处理该继承链条的执行。

Result:
[table=98%]
[tr][td]对比[/td][td]Compiling[/td][td]Execution[/td][/tr]
[tr][td]Smarty 3.1.1[/td][td]1.329 seconds[/td][td]0.002 seconds[/td][/tr]
[tr][td]Twig 1.2.0[/td][td]2.641 seconds[/td][td]0.121 seconds[/td][/tr]
[/table]Smarty快60倍以上。如果我们查看编译后的代码,会很容易明白还不止60倍。Smarty将整个模板的xx联合起来放到一个大文件中存放起来,执行起来就如同并不存在嵌套一样。也就是说,Smarty的xx机制计划没有任何的性能损失,Twig是小心地为每个xx模板建立类文件,并在执行期间一个个地嵌入并执行。

总结
结论很清晰:Smarty比Twig要更快,仅在一次性编译较大模板时耗费了更多的时间,但除此之外其他的操作均有更高的性能。
我们测试的环境是:奔腾双核T4200 (2 GHz),3GB内存,PHP5.3版本。如果你想在自己电脑上进行上述的性能测试,你可以在本文的最后下载全部代码。

文章来自:http://umumble.com/blogs/php/249/

2012-11-09 09:04:43

#2 jiayan41

昨天又看了一遍Smarty代码,真心感觉smarty的强大。

2012-11-09 10:47:13

#3 fosf

jake 的英文真棒:lol

2012-11-09 16:27:53

#4 WCPSOFT

学习了,谢谢

2012-11-11 10:14:45