前言
如果我們想知道某個方法被誰調(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í)價值,如果有疑問大家可以留言交流,謝謝大家對綠夏網(wǎng)的支持。