我正在寻找一种在PHP中打印调用堆栈的方法。
如果函数刷新IO缓冲区,则加分。
我正在寻找一种在PHP中打印调用堆栈的方法。
如果函数刷新IO缓冲区,则加分。
当前回答
您可能想查看debug_backtrace,或者debug_print_backtrace。
其他回答
请看看这个utils类,可能会有帮助:
用法:
<?php
/* first caller */
Who::callme();
/* list the entire list of calls */
Who::followme();
源类:https://github.com/augustowebd/utils/blob/master/Who.php
如果一个人只是对文件感兴趣,你可以使用以下:
print_r (array_column debug_backtrace()、“文件”);
同样地,您可以用不同的键替换文件,只是为了查看该数据。
如果你想生成一个反向跟踪,你需要寻找debug_backtrace和/或debug_print_backtrace。
例如,第一个会给你一个像这样的数组(引用手册):
array(2) {
[0]=>
array(4) {
["file"] => string(10) "/tmp/a.php"
["line"] => int(10)
["function"] => string(6) "a_test"
["args"]=>
array(1) {
[0] => &string(6) "friend"
}
}
[1]=>
array(4) {
["file"] => string(10) "/tmp/b.php"
["line"] => int(2)
["args"] =>
array(1) {
[0] => string(10) "/tmp/a.php"
}
["function"] => string(12) "include_once"
}
}
它们显然不会刷新I/O缓冲区,但您可以自己使用flush和/或ob_flush来实现这一点。
(请参阅第一个的手册页,找出为什么“and/or”;-))
debug_backtrace ()
使用debug_backtrace获取被调用的函数和方法的反向跟踪,以及被包含到调用debug_backtrace的位置的文件。