php 調(diào)試利器debug_print_backtrace()
更新時間:2012年07月23日 22:56:17 作者:
debug_print_backtrace() 是一個很低調(diào)的函數(shù),很少有人注意過它.
不過當我對著一個對象調(diào)用另一個對象再調(diào)用其它的對象和文件中的一個函數(shù)出錯時,它正在一邊笑呢
如果我們想知道某個方法被誰調(diào)用了? debug_print_backtrace可以解決
debug_print_backtrace() 可以打印出一個頁面的調(diào)用過程 , 從哪兒來到哪兒去一目了然.
不過這是一個PHP5的專有函數(shù),好在pear中已經(jīng)有了實現(xiàn),
http://pear.php.net/package/PHP_Compat
測試代碼
<?php
class a{
function say($msg) {
echo "msg:".$msg;
echo "<pre>";debug_print_backtrace();
}
}
class b {
function say($msg) {
$a = new a();
$a->say($msg);
}
}
class c {
function __construct($msg) {
$b = new b();
$b->say($msg);
}
}
$c = new c("test");
輸出結(jié)果
msg:test
#0 a->say(test) called at [/var/www/test/test0723.php:12]
#1 b->say(test) called at [/var/www/test/test0723.php:19]
#2 c->__construct(test) called at [/var/www/test/test0723.php:23]
相關(guān)鏈接
http://ch2.php.net/manual/zh/function.debug-print-backtrace.php
http://ch2.php.net/manual/zh/function.debug-backtrace.php
debug_print_backtrace() 可以打印出一個頁面的調(diào)用過程 , 從哪兒來到哪兒去一目了然.
不過這是一個PHP5的專有函數(shù),好在pear中已經(jīng)有了實現(xiàn),
http://pear.php.net/package/PHP_Compat
測試代碼
復制代碼 代碼如下:
<?php
class a{
function say($msg) {
echo "msg:".$msg;
echo "<pre>";debug_print_backtrace();
}
}
class b {
function say($msg) {
$a = new a();
$a->say($msg);
}
}
class c {
function __construct($msg) {
$b = new b();
$b->say($msg);
}
}
$c = new c("test");
輸出結(jié)果
復制代碼 代碼如下:
msg:test
#0 a->say(test) called at [/var/www/test/test0723.php:12]
#1 b->say(test) called at [/var/www/test/test0723.php:19]
#2 c->__construct(test) called at [/var/www/test/test0723.php:23]
相關(guān)鏈接
http://ch2.php.net/manual/zh/function.debug-print-backtrace.php
http://ch2.php.net/manual/zh/function.debug-backtrace.php
相關(guān)文章
php緩沖 output_buffering和ob_start使用介紹
這篇文章主要介紹了php緩沖 output_buffering和ob_start的相關(guān)資料,需要的朋友可以參考下2014-01-01