定義和用法
set_exception_handler() 函數設置用戶自定義的異常處理函數。
該函數用於創建運行時期間的用戶自己的異常處理方法。
該函數會返回舊的異常處理程序,若失敗,則返回 null。
語法
set_exception_handler(exception_function)
參數 | 描述 |
---|---|
error_function | 必需。規定未捕獲的異常發生時調用的函數。 該函數必須在調用 set_exception_handler() 函數之前定義。 這個異常處理函數需要需要一個參數,即拋出的 exception 對象。 |
提示和注釋
提示:在這個異常處理程序被調用后,腳本會停止執行。
例子
<?php function myException($exception) { echo "<b>Exception:</b> " , $exception->getMessage(); } set_exception_handler('myException'); throw new Exception('Uncaught Exception occurred'); ?>
輸出:
Exception: Uncaught Exception occurred
需要注意的是:
set_exception_handler(“myException”) 不僅可以接受函數,還可以接受 類的方法(公開的靜態方法 及 公開的非靜態方法 都可以),但需要以 數組形式 傳遞,數組的第一值為“類名”,第二個參數為“方法名”,如下代碼所示:
<?php class App{ function myException($exception) { echo "<b>Exception:</b> " , $exception->getMessage(); } } set_exception_handler(array('App','myException')); throw new Exception('Uncaught Exception occurred'); ?>
延伸閱讀: