PHP中調(diào)試函數(shù)debug_backtrace的使用示例代碼
前言
如果我們想知道某個方法被誰調(diào)用了? debug_backtrace可以解決。debug_backtrace() 可以打印出一個頁面的調(diào)用過程 , 從哪兒來到哪兒去一目了然。
有時候我們想知道這個函數(shù)或方法的調(diào)用堆棧,也就是它是如何一級一級是被調(diào)用到的,可以用 PHP 的 debug_backtrace 函數(shù)打印,就像這樣:
示例代碼
public function update(Request $request, $id) { dd(debug_backtrace()); $getGameID = function ($request) { if (!$request->game_id) { return 1000 + intval($request->id); } return $request->game_id; }; $previews = $this->getGamePreviews($request->game_preview); $request->merge([ 'game_preview' => json_encode($previews), 'game_id' => $getGameID($request) ]); EgretGame::where('id', $id)->update($request->except(['_token', '_method'])); return redirect()->route('egretgame.index')->with('success', '編輯成功!'); }
你可以控制需要回溯的堆棧層級數(shù)量,其中 debug_backtrace 第一個參數(shù)默認(rèn)是一個常量 DEBUG_BACKTRACE_PROVIDE_OBJECT
,表示顯示這個對象的信息,第二個參數(shù)用于控制回溯的堆棧數(shù)量,默認(rèn)是全部。
效果如圖所示,調(diào)用層級的關(guān)系一目了然:
PHP 官方文檔:http://php.net/manual/zh/function.debug-backtrace.php
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- php代碼調(diào)試?yán)鱢irephp安裝與使用方法分析
- PHP使用debug_backtrace方法跟蹤調(diào)試代碼調(diào)用詳解
- 使用GDB調(diào)試PHP代碼,解決PHP代碼死循環(huán)問題
- Windows和Linux中php代碼調(diào)試工具Xdebug的安裝與配置詳解
- PHP學(xué)習(xí)筆記 (1) 環(huán)境配置與代碼調(diào)試
- php開發(fā)最強(qiáng)大的IDE編輯的phpstorm 2020.2配置Xdebug調(diào)試的詳細(xì)教程
- 解決windows上php xdebug 無法調(diào)試的問題
- PhpStorm 如何優(yōu)雅的調(diào)試Hyperf的方法步驟
- 調(diào)試php程序的簡單步驟
- 如何運(yùn)行/調(diào)試你的PHP代碼
相關(guān)文章
使用PHP socke 向指定頁面提交數(shù)據(jù)
一直以為有了ajax別人網(wǎng)站的數(shù)據(jù)就可以拿過來用,這也是我這幾天想的一個方像,但是用了firefox測試之后,現(xiàn)在不能,2008-07-07WordPress開發(fā)中自定義菜單的相關(guān)PHP函數(shù)使用簡介
這篇文章主要介紹了WordPress開發(fā)中自定義菜單的相關(guān)PHP函數(shù)使用,包括過濾掉自定義菜單中無用的class值的方法,需要的朋友可以參考下2016-01-01關(guān)于PHP二進(jìn)制流 逐bit的低位在前算法(詳解)
本篇文章是對PHP二進(jìn)制流逐bit的低位在前算法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06php自定義函數(shù)轉(zhuǎn)換html標(biāo)簽示例
這篇文章主要介紹了php自定義函數(shù)轉(zhuǎn)換html標(biāo)簽的方法,結(jié)合實例形式分析了php針對字符串的編碼轉(zhuǎn)換與正則替換操作技巧,需要的朋友可以參考下2016-09-09