在给定的php代码中,child_func()函数调用parent_func()函数,该函数进一步调用grandparent_func()函数,从而生成调用堆栈。

推荐学习:《PHP教程》
PHP打印调用堆栈的三种方法如下:
方法1:使用debug_print_backtrace()函数打印调用堆栈。
例:
立即学习“PHP免费学习笔记(深入)”;
输出:
#0 grandparent_func() called at [/home/905a3b4d90f10b30521fedcb56c99fba.php:12] #1 parent_func() called at [/home/905a3b4d90f10b30521fedcb56c99fba.php:7] #2 child_func() called at [/home/905a3b4d90f10b30521fedcb56c99fba.php:21]
方法2:使用debug_backtrace()函数打印调用堆栈。
例:
立即学习“PHP免费学习笔记(深入)”;
输出:
array(3) {
[0]=>
array(4) {
["file"]=>
string(42) "/home/2b81f040639170c49a6a58adb23d5154.php"
["line"]=>
int(12)
["function"]=>
string(16) "grandparent_func"
["args"]=>
array(0) {
}
}
[1]=>
array(4) {
["file"]=>
string(42) "/home/2b81f040639170c49a6a58adb23d5154.php"
["line"]=>
int(7)
["function"]=>
string(11) "parent_func"
["args"]=>
array(0) {
}
}
[2]=>
array(4) {
["file"]=>
string(42) "/home/2b81f040639170c49a6a58adb23d5154.php"
["line"]=>
int(21)
["function"]=>
string(10) "child_func"
["args"]=>
array(0) {
}
}
}方法3: Exception类的getTraceAsString()成员函数返回一个调用堆栈。
例:
立即学习“PHP免费学习笔记(深入)”;
getTraceAsString()); } // 主函数调用 child_func(); ?>
输出:
string(207) "#0 /home/8d8303d43667a4915d43dab7d63de26d.php(12): grandparent_func()
#1 /home/8d8303d43667a4915d43dab7d63de26d.php(7): parent_func()
#2 /home/8d8303d43667a4915d43dab7d63de26d.php(22): child_func()
#3 {main}"本篇文章就是关于PHP怎么打印调用堆栈的三种方法介绍,希望对需要的朋友有所帮助!











