今天网站出现一个BUG,然后直接在数据库类里面写日志,看是哪条SQL出了问题,SQL语句到是找到了,但是不知道这条SQL语句来自何处,于是就想啊,如果能有一个办法,查看当前正在运行的这个方法是被哪个方法调用的,以及上一个方法又是哪个方法调用的,以此类推,找到入口地址多好啊。不过以前自己也想过,也在网上去搜过,就是没有找到相关的办法,今天一同事(前辈)说JAVA里面这种调试用得很普遍,叫这种堆栈调试,我是就在网上搜PHP堆栈。居然被我找到了,然后把自己的办法写出来。
//调用堆栈函数,查找调用函数的源头,方便调试 function print_stack_trace() { $array =debug_backtrace(); //print_r($array);//信息很齐全 unset($array[0]); foreach($array as $row) { $html .= $row['file'].':'.$row['line'].'行,调用方:'.$row['function']."<p>"; } return $html; }
我在我的数据库的核心查询函数里面调用这个方法,打印结果如下:
D:wampwwwmeileleincludescls_mysql.php:471行,调用方法:query D:wampwwwmeileleincludescls_mysql.php:507行,调用方法:getAll D:wampwwwmeileleincludeslib_common.php:732行,调用方法:getAllCached D:wampwwwmeileleincludesinit.php:113行,调用方法:load_config D:wampwwwmeileleindex.php:4行,调用方法:include_once
一目了然,一直找到了入口,太强悍了。以后调试又多了一种办法