前言
如果我們想知道某個(gè)方法被誰(shuí)調(diào)用了? debug_backtrace可以解決。debug_backtrace() 可以打印出一個(gè)頁(yè)面的調(diào)用過(guò)程 , 從哪兒來(lái)到哪兒去一目了然。
有時(shí)候我們想知道這個(gè)函數(shù)或方法的調(diào)用堆棧,也就是它是如何一級(jí)一級(jí)是被調(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', '編輯成功!'); }
你可以控制需要回溯的堆棧層級(jí)數(shù)量,其中 debug_backtrace 第一個(gè)參數(shù)默認(rèn)是一個(gè)常量 DEBUG_BACKTRACE_PROVIDE_OBJECT
,表示顯示這個(gè)對(duì)象的信息,第二個(gè)參數(shù)用于控制回溯的堆棧數(shù)量,默認(rèn)是全部。
效果如圖所示,調(diào)用層級(jí)的關(guān)系一目了然:
PHP 官方文檔:http://php.net/manual/zh/function.debug-backtrace.php
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)的支持。
【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。