PHP 使用 debug_print_backtrace() 或 debug_backtrace() 打印栈轨迹

时间:2022-11-03 16:23:57
<?php

/* 使用debug_print_backtrace() 或 debug_backtrace() 打印栈轨迹 */

function fun1() {
	print "Hello world!\n";
	fun2();
}

function fun2() {
	Class1::fun3();
}

Class Class1 {
	static function fun3() {
		$class2 = new Class2();
		$class2->fun4();
	}
}

class Class2 {
	function fun4() {
		debug_print_backtrace();
		$backtrace = debug_backtrace();
		echo '<pre>';
		print_r($backtrace);
	}
}

fun1();

输出:

Hello world!
#0  Class2->fun4() called at [D:\wamp\www\practise\php\phpcookbook\error\track.php.php:17]
#1  Class1::fun3() called at [D:\wamp\www\practise\php\phpcookbook\error\track.php.php:11]
#2  fun2() called at [D:\wamp\www\practise\php\phpcookbook\error\track.php.php:7]
#3  fun1() called at [D:\wamp\www\practise\php\phpcookbook\error\track.php.php:30]
<pre>Array
(
	[0] => Array
    (
	    [file] => D:\wamp\www\practise\php\phpcookbook\error\track.php.php
	    [line] => 17
	    [function] => fun4
	    [class] => Class2
	    [object] => Class2 Object
        (
        )

	    [type] => ->
	    [args] => Array
        (
        )
    )

	[1] => Array
	    (
        [file] => D:\wamp\www\practise\php\phpcookbook\error\track.php.php
        [line] => 11
        [function] => fun3
        [class] => Class1
        [type] => ::
        [args] => Array
          (
          )
    )

	[2] => Array
    (
      [file] => D:\wamp\www\practise\php\phpcookbook\error\track.php.php
      [line] => 7
      [function] => fun2
      [args] => Array
        (
        )
    )

	[3] => Array
    (
      [file] => D:\wamp\www\practise\php\phpcookbook\error\track.php.php
      [line] => 30
      [function] => fun1
      [args] => Array
        (
        )
    )
)

  

参考:

<PHP Cookbook>3'rd