VLD是个好东西

转自:http://hi.baidu.com/thinkinginlamp/blog/item/62802f2e4b5edc584fc226a4.html

 

VLD全名是Vulcan Logic Disassembler,可以用来检测PHP脚本的执行情况。

安装VLD:

wget http://pecl.php.net/get/vld
tar zxvf vld-0.9.1.tgz
cd vld-0.9.1
phpize
./configure
make install


编辑php.ini文件激活vld扩展:

extension=vld.so

别忘了重启Apache。

下面我们看看如何检测PHP脚本的执行情况,看看PHP是如何处理单双引号字符串的:

s.php(单引号):<?php echo 'hello, world.'; ?>
d.php(双引号):<?php echo "hello, world."; ?>

开始检测:

php -dvld.active=1 s.php或者d.php

结果不管是s.php还是d.php,number of ops都是3,内容也都一样:

number of ops: 3
compiled vars: none
line     # op                           fetch          ext return operands
-------------------------------------------------------------------------------
   1     0 ECHO                                                     'hello%2C+world.'
   2     1 RETURN                                                   1
         2* ZEND_HANDLE_EXCEPTION


通常人们总是说,单引号比双引号快。但正如上面的实验结果显示,如果仅仅是输出一个常量字符串,那么单引号和双引号的效率其实是一样的。

实际编程时,总会遇到各种各样的选择:是empty好还是isset好?是in_array好还是array_key_exists好?此时不妨试试VLD,对比看看各种选择的number of ops都是多少,并且具体都干了些什么。自然就能得到正确的选择,而不用靠着主观猜测去臆断。

 

 

挺有意思,有时间玩一下,不过有精力有能力的话最好可以研究一下PHP源码,这样更好,:)

你可能感兴趣的:(apache,PHP,exception,脚本,Zend,extension)