Dado un código PHP y la tarea es imprimir la pila de llamadas para este código PHP. En el código PHP dado, una función child_func() llama a la función parent_func(), que además llama a la función grandparent_func(), lo que da como resultado una pila de llamadas.
Enfoque 1: Imprima la pila de llamadas usando la función debug_print_backtrace() .
Ejemplo:
<?php // PHP program to print PHP call stack // Function to call parent_func function child_func() { parent_func(); } // Function to call grandparent_func function parent_func() { grandparent_func(); } // Function to print call stack function grandparent_func() { debug_print_backtrace(); } // Main function call child_func(); ?>
Producción:
#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]
Enfoque 2: Imprima la pila de llamadas usando la función debug_backtrace() .
Ejemplo:
<?php // PHP program to print PHP call stack // Function to call parent_func function child_func() { parent_func(); } // Function to call grandparent_func function parent_func() { grandparent_func(); } // Function to print call stack function grandparent_func() { var_dump(debug_backtrace()); } // Main function call child_func(); ?>
Producción:
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) { } } }
Enfoque 3: la función miembro getTraceAsString() de la clase Exception devuelve una pila de llamadas.
Ejemplo:
<?php // PHP program to print PHP call stack // Function to call parent_func function child_func() { parent_func(); } // Function to call grandparent_func function parent_func() { grandparent_func(); } // Function to print call stack function grandparent_func() { $e = new Exception; var_dump($e->getTraceAsString()); } // Main function call child_func(); ?>
Producción:
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}"
Publicación traducida automáticamente
Artículo escrito por Harshit Saini y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA