-
- error_reporting(E_ALL&~E_NOTICE) ; // 除了E_NOTICE其他例外都會被觸發(E_ALL&~E_NOTICE的二進位運算結果是:E_NOTICE0 )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 ) 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 $intcode $str 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 int getCode ( void ) //定義的
- final public string getFile ( void ) //發生異常的檔案路勁
- final public int getLine ( void ) //發生異常的行
- final public array getTrace ( 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
- // 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';
- }
- 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() 函數 。
|