西西軟件下載最安全的下載網(wǎng)站、值得信賴的軟件下載站!

首頁編程開發(fā)php教程 → PHP 的錯誤、異常等級常量表,異常處理及錯誤回調(diào)函數(shù)

PHP 的錯誤、異常等級常量表,異常處理及錯誤回調(diào)函數(shù)

相關(guān)軟件相關(guān)文章發(fā)表評論 來源:西西整理時間:2012/12/5 11:20:56字體大。A-A+

作者:ecalf點擊:0次評論:0次標(biāo)簽: 異常處理

PHP 5 提供了一種新的面向?qū)ο蟮腻e誤處理方法。

異常處理用于在指定的錯誤(異常)情況發(fā)生時改變腳本的正常流程。這種情況稱為異常。

PHP 5 添加了類似于其它語言的異常處理模塊。在 PHP 代碼中所產(chǎn)生的異?杀 throw 語句拋出并被 catch 語句捕獲。需要進行異常處理的代碼都必須放入 try 代碼塊內(nèi),以便捕獲可能存在的異常。每一個 try 至少要有一個與之對應(yīng)的 catch。使用多個 catch 可以捕獲不同的類所產(chǎn)生的異常。當(dāng) try 代碼塊不再拋出異常或者找不到 catch 能匹配所拋出的異常時,PHP 代碼就會在跳轉(zhuǎn)到最后一個 catch 的后面繼續(xù)執(zhí)行。當(dāng)然,PHP 允許在 catch 代碼塊內(nèi)再次拋出(throw)異常。

當(dāng)一個異常被拋出時,其后(譯者注:指拋出異常時所在的代碼塊)的代碼將不會繼續(xù)執(zhí)行,而 PHP 就會嘗試查找第一個能與之匹配的 catch。如果一個異常沒有被捕獲,而且又沒用使用 set_exception_handler() 作相應(yīng)的處理的話,那么 PHP 將會產(chǎn)生一個嚴重的錯誤,并且輸出 Uncaught Exception ... (未捕獲異常)的提示信息。

當(dāng)異常被觸發(fā)時,通常會發(fā)生:

•當(dāng)前代碼狀態(tài)被保存
•代碼執(zhí)行被切換到預(yù)定義的異常處理器函數(shù)
•根據(jù)情況,處理器也許會從保存的代碼狀態(tài)重新開始執(zhí)行代碼,終止腳本執(zhí)行,或從代碼中另外的位置繼續(xù)執(zhí)行腳本

一、錯誤、異常 等級常量表

error:不能在編譯期發(fā)現(xiàn)的運行期錯誤,不如試圖用 echo 輸出一個未賦值的變量,這類問題往往導(dǎo)致程序或邏輯無法繼續(xù)下去而需要中斷;

exception:程序執(zhí)行過程中出現(xiàn)意料之外的情況,邏輯上往往是行得通的,但不符合應(yīng)用場景,比如接收到一個長度長錯預(yù)定格式的用戶命名,因此,異常主要靠編碼人員做預(yù)先做判斷后拋出,捕獲異常后改變程序流程來處理這些情況,不必中斷程序。

 PHP 對于異常和錯誤的界定似乎不是很明顯,尤其是低版本的PHP。

錯誤和日志記錄值    常量    說明   備注
1                        E_ERROR (integer)           

致命的運行時錯誤。這類錯誤一般是不可恢復(fù)的情況,例如內(nèi)存分配導(dǎo)致的問題。后果是導(dǎo)致腳本終止不再繼續(xù)運行。  

2                        E_WARNING (integer)         

運行時警告 (非致命錯誤)。僅給出提示信息,但是腳本不會終止運行。  

4                        E_PARSE (integer)          

 編譯時語法解析錯誤。解析錯誤僅僅由分析器產(chǎn)生。  

8                        E_NOTICE (integer)          

運行時通知。表示腳本遇到可能會表現(xiàn)為錯誤的情況,但是在可以正常運行的腳本里面也可能會有類似的通知。  

16                      E_CORE_ERROR(integer)       

 在PHP初始化啟動過程中發(fā)生的致命錯誤。該錯誤類似 E_ERROR,但是是由PHP引擎核心產(chǎn)生的。 since PHP 4

32                      E_CORE_WARNING(integer)        

 PHP初始化啟動過程中發(fā)生的警告 (非致命錯誤) 。類似 E_WARNING,但是是由PHP引擎核心產(chǎn)生的。 since PHP 4

64                      E_COMPILE_ERROR(integer)          

致命編譯時錯誤。類似E_ERROR, 但是是由Zend腳本引擎產(chǎn)生的。 since PHP 4

128                    E_COMPILE_WARNING(integer)          

編譯時警告 (非致命錯誤)。類似 E_WARNING,但是是由Zend腳本引擎產(chǎn)生的。 since PHP 4

256                    E_USER_ERROR(integer)          

用戶產(chǎn)生的錯誤信息。類似 E_ERROR, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來產(chǎn)生的。 since PHP 4

512                    E_USER_WARNING(integer)         

 用戶產(chǎn)生的警告信息。類似 E_WARNING, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來產(chǎn)生的。 since PHP 4

1024                  E_USER_NOTICE(integer)           

用戶產(chǎn)生的通知信息。類似 E_NOTICE, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來產(chǎn)生的。 since PHP 4

2048                  E_STRICT (integer)           

 啟用 PHP 對代碼的修改建議,以確保代碼具有最佳的互操作性和向前兼容性。 since PHP 5

4096                  E_RECOVERABLE_ERROR(integer)           

可被捕捉的致命錯誤。 它表示發(fā)生了一個可能非常危險的錯誤,但是還沒有導(dǎo)致PHP引擎處于不穩(wěn)定的狀態(tài)。 如果該錯誤沒有被用戶自定義句柄捕獲 (參見 set_error_handler()),將成為一個 E_ERROR 從而腳本會終止運行。 since PHP 5.2.0

8192                  E_DEPRECATED(integer)       

 運行時通知。啟用后將會對在未來版本中可能無法正常工作的代碼給出警告。 since PHP 5.3.0


16384                E_USER_DEPRECATED(integer)        

用戶產(chǎn)少的警告信息。 類似 E_DEPRECATED, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來產(chǎn)生的。 since PHP 5.3.0


30719                E_ALL (integer)       

E_STRICT出外的所有錯誤和警告信息。 30719 in PHP 5.3.x, 6143 in PHP 5.2.x, 2047 previously

二、error_reporting() 及 try-catch、thrown 

error_reporting() 函數(shù)可以獲取(不傳參時)、設(shè)定腳本處理哪些異常(并非所有異常都需要處理,例如 E_CORE_WARNING、E_NOTICE、E_DEPRECATED 是可以忽略的),該設(shè)定將覆蓋 php.ini 中 error_reporting選項定義的異常處理設(shè)定。

例如: 

error_reporting(E_ALL&~E_NOTICE) ; // 除了E_NOTICE其他異常都會被觸發(fā)(E_ALL&~E_NOTICE的二進制運算結(jié)果是:E_NOTICE對應(yīng)位的值被設(shè)置為0)

try-catch 無法在類的自動加載函數(shù) __autoload() 內(nèi)生效。

try-catch 無法用于捕獲異常,無法捕獲錯誤,例如 trigger_error() 觸發(fā)的錯誤,異常和錯誤是不一樣的。

try{

  // you codes that maybe cause an error

}catch(Exception $err){ // 這個錯誤對象需要聲明類型, Exception 是系統(tǒng)默認異常處理類

    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 類的結(jié)構(gòu):其中大部分方法都是 禁止改寫的(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 ) //發(fā)生異常的文件路勁

final public int getLine ( void ) //發(fā)生異常的行

final public array getTrace ( void ) //異常追蹤信息(array)

final public string getTraceAsString ( void ) //異常追蹤信息(string)

public string __toString ( void ) //試圖直接 將異常對象當(dāng)作字符串使用時調(diào)用子函數(shù)的返回值

final private void __clone ( void ) //克隆異常對象時調(diào)用

}

擴展異常類

try-catch 可以有多個 catch 子句,從第一個 catch 子句開始,如果子句內(nèi)的 異常變量 類型匹配 thrown 語句拋出的異常類型,則該子句會被執(zhí)行而不再執(zhí)行其他catch子句,否則繼續(xù)嘗試下一個 catch 子句,由于Exception 是所有 異常類的基類,因此拋出的異常都會與他匹配 ,如果你像個根據(jù)不同異常類型使用不同的處理方法,應(yīng)該將 Exception 類型的 catch 子句放到最后。 

Exception 是所有異常的基類,可以根據(jù)實際需要擴展異常類,

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 子句中判斷異常的類型,或者根據(jù) code 等信息來決定是否處理異常,如果你卸載 catch 子句的代碼無法適當(dāng)?shù)奶幚聿东@的異常,你可以在 catch 子句內(nèi)繼續(xù) 拋出異常。

三 、 Exception 異常的回調(diào)函數(shù)

set_exception_handler(callback functionName)  //發(fā)生 Exception 或其 子類的 異常是會調(diào)用此函數(shù)

function exceptionHandlerFun($errObj){  // Exception 異常的回調(diào)函數(shù) 只有一個參數(shù),就是拋出的異常對象。

//.......

}

 Exception 異常的回調(diào)函數(shù)并不能像  set_error_handler 的回調(diào)函數(shù)那樣通過返回 true 來使異常被消除,即使回調(diào)函數(shù)處理了異常,后繼代碼也不會被繼續(xù)執(zhí)行,因此想繼續(xù)執(zhí)行后續(xù)代碼必須使用 try-catch。

但是有一個例外:腳本結(jié)束回調(diào)函數(shù)可以被執(zhí)行,拋出的異常即使沒有被處理,該回調(diào)函數(shù)也是能被執(zhí)行的。

register_shutdown_function(callback functionName[,argument1,argument2,...]);

例如:

function shutdownfunction(){

    echo 'script is end';

}

register_shutdown_function("shutdownfunction");

因為 shutdownfunction() 在腳本結(jié)束時被執(zhí)行,所以 這個回調(diào)函數(shù)之內(nèi)可以調(diào)用腳本中任意位置的函數(shù),即使該函數(shù)定義在 錯誤拋出位置之后(函數(shù)定義是在 腳本編譯期完成的)。

四、trigger_error(string errorMsg[,int user_error_type]) 

 該函數(shù)用于主動觸發(fā)一個錯誤: user_error_type 只能是 E_ALL、E_USER_ERROR、 E_USER_WARNING、 E_USER_NOTICE 或其組合的值。

set_error_handler(callbeck functionName[,user_error_type]); // 為 trigger_error() 設(shè)置一個回調(diào)函數(shù)來處理錯誤,包括系統(tǒng)拋出的錯誤和用戶使用 trigger_error() 函數(shù)觸發(fā)的錯誤。

可選參數(shù) user_error_type :

如果設(shè)定此參數(shù),則 trigger_error 拋出的錯誤類型符合 在user_error_type 的定義范圍才能觸發(fā)回調(diào)函數(shù)。

這個值的設(shè)置類似于 error_reporting() 函數(shù) 。

第一個參數(shù)(callbeck functionName):

一個函數(shù)名,該函數(shù) 可以有 5 個參數(shù),其中前 2 個必選,依次是:

trigger_error 拋出的 user_error_type、trigger_error 拋出的 errorMsg、拋出錯誤的文件的絕對路勁、拋出錯誤的行號、拋出錯誤時的上下文環(huán)境 (一個數(shù)組,包含了trigger_error() 所在作用域內(nèi)的所有變量、函數(shù)、類等數(shù)據(jù) )

回調(diào)函數(shù)的返回值: 如果返回 false ,系統(tǒng)錯誤處理機制仍然繼續(xù)拋出該錯誤,返回 true 或 無返回值 則消除錯誤。

 trigger_error()  觸發(fā)的錯誤不會被 try-catch 異常捕獲語句捕獲。

    相關(guān)評論

    閱讀本文后您有什么感想? 已有人給出評價!

    • 8 喜歡喜歡
    • 3 頂
    • 1 難過難過
    • 5 囧
    • 3 圍觀圍觀
    • 2 無聊無聊

    熱門評論

    最新評論

    發(fā)表評論 查看所有評論(0)

    昵稱:
    表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
    字數(shù): 0/500 (您的評論需要經(jīng)過審核才能顯示)
    推薦文章

    沒有數(shù)據(jù)

      沒有數(shù)據(jù)
    最新文章
      沒有數(shù)據(jù)