- error_reporting(E_ALL&~E_NOTICE) ; // 除了E_NOTICE其他異常都會被觸發(E_ALL&~E_NOTICE的二進位運算結果是:E_NOTICE對應位的值被設定為0)try-catch 無法在類的自動載入函數 __autoload() 內生效。
- try-catch 無法用於捕獲異常,無法捕獲錯誤,例如 trigger_error() 觸發的錯誤,異常和錯誤是不一樣的。
- try{
- // you codes that maybe cause an error
- }catch(Exception $err){ // 這個錯誤對象需要宣告類型, Exception 是系統預設異常處理類
- echo $err->getMessage();
- }
複製代碼//thrown 可以拋出一個異常,如:thrown new Exception('an error');一個例子:
- try {
- if ( empty( $var1 ) ) throw new NotEmptyException();
- if ( empty( $var2 ) ) throw new NotEmptyException();
- if ( ! preg_match() ) throw new InvalidInputException();
- $model->write();
- $template->render( 'success' );
- } catch ( NotEmptyException $e ) {
- $template->render( 'error_empty' );
- } catch ( InvalidInputException $e ) {
- $template->render( 'error_preg' );
- }
複製代碼Exception 類的結構:其中大部分方法都是 禁止改寫的(final )
- Exception {
- /* 屬性 */
- protected string $message ;
- protected int $code ;
- protected string $file ;
- protected int $line ;
- /* 方法 */
- public __construct ([ string $message = "" [, int $code = 0 [, Exception $previous = null]]] )
- final public string getMessage ( void ) //異常拋出的資訊
- final public Exception getPrevious ( void ) //前一異常
- final public int getCode ( void ) //異常代碼,這是使用者自訂的
- final public string getFile ( void ) //發生異常的檔案路勁
- final public int getLine ( void ) //發生異常的行
- final public array getTrace ( void ) //異常追蹤資訊(array)
- final public string getTraceAsString ( void ) //異常追蹤資訊(string)
- public string __toString ( void ) //試圖直接 將異常對象當作字串使用時調用子函數的傳回值
- final private void __clone ( void ) //複製異常對象時調用
- }
複製代碼擴充異常類try-catch 可以有多個 catch 子句,從第一個 catch 子句開始,如果子句內的 異常變數 類型匹配 thrown 語句拋出的異常類型,則該子句會被執行而不再執行其他catch子句,否則繼續嘗試下一個 catch 子句,由於Exception 是所有 異常類的基類,因此拋出的異常都會與他匹配 ,如果你像個根據不同異常類型使用不同的處理方法,應該將 Exception 類型的 catch 子句放到最後。Exception 是所有異常的基類,可以根據實際需要擴充異常類,
- calss MyException extends Exception{
- public errType = 'default';
- public function __construct($errType=''){
- $this->errType = $errType;
- }
- }
- thrown new MyException (); //拋出一個異常
- try{
- // you codes that maybe cause an error
- }catch(MyException $err){ // 這個錯誤對象需要宣告類型
- echo $err->errType();
- }catch(ErrorException $err){ //ErrorException 是 PHP 5 增加的異常類,繼承於 Exception
- echo 'error !';
- }catch(Exception $err){
- redirect('/error.php');
- }
複製代碼你可能會在 catch 子句中判斷異常的類型,或者根據 code 等資訊來決定是否處理異常,如果你卸載 catch 子句的代碼無法適當的處理捕獲的異常,你可以在 catch 子句內繼續 拋出異常。 三、Exception 異常的回呼函數set_exception_handler(callback functionName) //發生 Exception 或其 子類的 異常是會調用此函數function exceptionHandlerFun($errObj){ // Exception 異常的回呼函數 只有一個參數,就是拋出的異常對象。//.......} Exception 異常的回呼函數並不能像 set_error_handler 的回呼函數那樣通過返回 true 來使異常被消除,即使回呼函數處理了異常,後繼代碼也不會被繼續執行,因此想繼續執行後續代碼必須使用 try-catch。但是有一個例外:指令碼結束回呼函數可以被執行,拋出的異常即使沒有被處理,該回呼函數也是能被執行的。register_shutdown_function(callback functionName[,argument1,argument2,...]);例如:
function shutdownfunction(){
- echo 'script is end';
- }
register_shutdown_function("shutdownfunction");
-
複製代碼因為 shutdownfunction() 在指令碼結束時被執行,所以 這個回呼函數之內可以呼叫指令碼中任意位置的函數,即使該函數定義在 錯誤拋出位置之後(函數定義是在 指令碼編譯期完成的)。 四、trigger_error(string errorMsg[,int user_error_type])該函數用於主動觸發一個錯誤: user_error_type 只能是 E_ALL、E_USER_ERROR、 E_USER_WARNING、 E_USER_NOTICE 或其組合的值。set_error_handler(callbeck functionName[,user_error_type]); // 為 trigger_error() 設定一個回呼函數來處理錯誤,包括系統拋出的錯誤和使用者使用 trigger_error() 函數觸發的錯誤。 選擇性參數 user_error_type :如果設定此參數,則 trigger_error 拋出的錯誤類型符合 在user_error_type 的定義範圍才能觸發回呼函數。這個值的設定類似於 error_reporting() 函數 。 第一個參數(callbeck functionName):一個函數名,該函數 可以有 5 個參數,其中前 2 個必選,依次是:trigger_error 拋出的 user_error_type、trigger_error 拋出的 errorMsg、拋出錯誤的檔案的絕對路勁、拋出錯誤的行號、拋出錯誤時的上下文環境 (一個數組,包含了trigger_error() 所在範圍內的所有變數、函數、類等資料 )回呼函數的傳回值: 如果返回 false ,系統錯誤處理機制仍然繼續拋出該錯誤,返回 true 或 無傳回值 則消除錯誤。trigger_error() 觸發的錯誤不會被 try-catch 異常捕獲語句捕獲。 |