我正在寻找一种在PHP中打印调用堆栈的方法。
如果函数刷新IO缓冲区,则加分。
我正在寻找一种在PHP中打印调用堆栈的方法。
如果函数刷新IO缓冲区,则加分。
当前回答
奇怪的是没有人这样发帖:
debug_print_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS);
这实际上是在没有垃圾的情况下打印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”;-))
Walltearer的解决方案非常出色,特别是如果包含在'pre'标签中:
<pre>
<?php debug_print_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS); ?>
</pre>
-它将调用放在单独的行上,整齐地编号
看到debug_print_backtrace。我想如果你想的话,你可以之后再喊冲水。
使用debug_backtrace获取被调用的函数和方法的反向跟踪,以及被包含到调用debug_backtrace的位置的文件。
debug_backtrace ()