PHP 的異常處理、錯(cuò)誤的拋出及回調(diào)函數(shù)等面向?qū)ο蟮腻e(cuò)誤處理方法
更新時(shí)間:2012年12月07日 11:31:28 作者:
PHP 5 提供了一種新的面向?qū)ο蟮腻e(cuò)誤處理方法,包括PHP 的異常處理、錯(cuò)誤的拋出及回調(diào)函數(shù)等面向?qū)ο蟮腻e(cuò)誤處理方法,需要了解更多的朋友可以參考下
異常處理用于在指定的錯(cuò)誤(異常)情況發(fā)生時(shí)改變腳本的正常流程。這種情況稱為異常。
PHP 5 添加了類似于其它語(yǔ)言的異常處理模塊。在 PHP 代碼中所產(chǎn)生的異常可被 throw 語(yǔ)句拋出并被 catch 語(yǔ)句捕獲。需要進(jìn)行異常處理的代碼都必須放入 try 代碼塊內(nèi),以便捕獲可能存在的異常。每一個(gè) try 至少要有一個(gè)與之對(duì)應(yīng)的 catch。使用多個(gè) catch 可以捕獲不同的類所產(chǎn)生的異常。當(dāng) try 代碼塊不再拋出異?;蛘哒也坏?catch 能匹配所拋出的異常時(shí),PHP 代碼就會(huì)在跳轉(zhuǎn)到最后一個(gè) catch 的后面繼續(xù)執(zhí)行。當(dāng)然,PHP 允許在 catch 代碼塊內(nèi)再次拋出(throw)異常。
當(dāng)一個(gè)異常被拋出時(shí),其后(譯者注:指拋出異常時(shí)所在的代碼塊)的代碼將不會(huì)繼續(xù)執(zhí)行,而 PHP 就會(huì)嘗試查找第一個(gè)能與之匹配的 catch。如果一個(gè)異常沒(méi)有被捕獲,而且又沒(méi)用使用 set_exception_handler() 作相應(yīng)的處理的話,那么 PHP 將會(huì)產(chǎn)生一個(gè)嚴(yán)重的錯(cuò)誤,并且輸出 Uncaught Exception ... (未捕獲異常)的提示信息。
當(dāng)異常被觸發(fā)時(shí),通常會(huì)發(fā)生:
•當(dāng)前代碼狀態(tài)被保存
•代碼執(zhí)行被切換到預(yù)定義的異常處理器函數(shù)
•根據(jù)情況,處理器也許會(huì)從保存的代碼狀態(tài)重新開始執(zhí)行代碼,終止腳本執(zhí)行,或從代碼中另外的位置繼續(xù)執(zhí)行腳本
一、錯(cuò)誤、異常 等級(jí)常量表
error:不能在編譯期發(fā)現(xiàn)的運(yùn)行期錯(cuò)誤,不如試圖用 echo 輸出一個(gè)未賦值的變量,這類問(wèn)題往往導(dǎo)致程序或邏輯無(wú)法繼續(xù)下去而需要中斷;
exception:程序執(zhí)行過(guò)程中出現(xiàn)意料之外的情況,邏輯上往往是行得通的,但不符合應(yīng)用場(chǎng)景,比如接收到一個(gè)長(zhǎng)度長(zhǎng)錯(cuò)預(yù)定格式的用戶命名,因此,異常主要靠編碼人員做預(yù)先做判斷后拋出,捕獲異常后改變程序流程來(lái)處理這些情況,不必中斷程序。
PHP 對(duì)于異常和錯(cuò)誤的界定似乎不是很明顯,尤其是低版本的PHP。
錯(cuò)誤和日志記錄值 常量 說(shuō)明 備注
1 E_ERROR (integer)
致命的運(yùn)行時(shí)錯(cuò)誤。這類錯(cuò)誤一般是不可恢復(fù)的情況,例如內(nèi)存分配導(dǎo)致的問(wèn)題。后果是導(dǎo)致腳本終止不再繼續(xù)運(yùn)行。
2 E_WARNING (integer)
運(yùn)行時(shí)警告 (非致命錯(cuò)誤)。僅給出提示信息,但是腳本不會(huì)終止運(yùn)行。
4 E_PARSE (integer)
編譯時(shí)語(yǔ)法解析錯(cuò)誤。解析錯(cuò)誤僅僅由分析器產(chǎn)生。
8 E_NOTICE (integer)
運(yùn)行時(shí)通知。表示腳本遇到可能會(huì)表現(xiàn)為錯(cuò)誤的情況,但是在可以正常運(yùn)行的腳本里面也可能會(huì)有類似的通知。
16 E_CORE_ERROR(integer)
在PHP初始化啟動(dòng)過(guò)程中發(fā)生的致命錯(cuò)誤。該錯(cuò)誤類似 E_ERROR,但是是由PHP引擎核心產(chǎn)生的。 since PHP 4
32 E_CORE_WARNING(integer)
PHP初始化啟動(dòng)過(guò)程中發(fā)生的警告 (非致命錯(cuò)誤) 。類似 E_WARNING,但是是由PHP引擎核心產(chǎn)生的。 since PHP 4
64 E_COMPILE_ERROR(integer)
致命編譯時(shí)錯(cuò)誤。類似E_ERROR, 但是是由Zend腳本引擎產(chǎn)生的。 since PHP 4
128 E_COMPILE_WARNING(integer)
編譯時(shí)警告 (非致命錯(cuò)誤)。類似 E_WARNING,但是是由Zend腳本引擎產(chǎn)生的。 since PHP 4
256 E_USER_ERROR(integer)
用戶產(chǎn)生的錯(cuò)誤信息。類似 E_ERROR, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 since PHP 4
512 E_USER_WARNING(integer)
用戶產(chǎn)生的警告信息。類似 E_WARNING, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 since PHP 4
1024 E_USER_NOTICE(integer)
用戶產(chǎn)生的通知信息。類似 E_NOTICE, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 since PHP 4
2048 E_STRICT (integer)
啟用 PHP 對(duì)代碼的修改建議,以確保代碼具有最佳的互操作性和向前兼容性。 since PHP 5
4096 E_RECOVERABLE_ERROR(integer)
可被捕捉的致命錯(cuò)誤。 它表示發(fā)生了一個(gè)可能非常危險(xiǎn)的錯(cuò)誤,但是還沒(méi)有導(dǎo)致PHP引擎處于不穩(wěn)定的狀態(tài)。 如果該錯(cuò)誤沒(méi)有被用戶自定義句柄捕獲 (參見 set_error_handler()),將成為一個(gè) E_ERROR 從而腳本會(huì)終止運(yùn)行。 since PHP 5.2.0
8192 E_DEPRECATED(integer)
運(yùn)行時(shí)通知。啟用后將會(huì)對(duì)在未來(lái)版本中可能無(wú)法正常工作的代碼給出警告。 since PHP 5.3.0
16384 E_USER_DEPRECATED(integer)
用戶產(chǎn)少的警告信息。 類似 E_DEPRECATED, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 since PHP 5.3.0
30719 E_ALL (integer)
E_STRICT出外的所有錯(cuò)誤和警告信息。 30719 in PHP 5.3.x, 6143 in PHP 5.2.x, 2047 previously
二、error_reporting() 及 try-catch、thrown
error_reporting() 函數(shù)可以獲取(不傳參時(shí))、設(shè)定腳本處理哪些異常(并非所有異常都需要處理,例如 E_CORE_WARNING、E_NOTICE、E_DEPRECATED 是可以忽略的),該設(shè)定將覆蓋 php.ini 中 error_reporting選項(xiàng)定義的異常處理設(shè)定。
例如:
error_reporting(E_ALL&~E_NOTICE) ; // 除了E_NOTICE其他異常都會(huì)被觸發(fā)(E_ALL&~E_NOTICE的二進(jìn)制運(yùn)算結(jié)果是:E_NOTICE對(duì)應(yīng)位的值被設(shè)置為0)try-catch 無(wú)法在類的自動(dòng)加載函數(shù) __autoload() 內(nèi)生效。
try-catch 無(wú)法用于捕獲異常,無(wú)法捕獲錯(cuò)誤,例如 trigger_error() 觸發(fā)的錯(cuò)誤,異常和錯(cuò)誤是不一樣的。
try{
// you codes that maybe cause an error
}catch(Exception $err){ // 這個(gè)錯(cuò)誤對(duì)象需要聲明類型, Exception 是系統(tǒng)默認(rèn)異常處理類
echo $err->getMessage();
}
//thrown 可以拋出一個(gè)異常,如:
thrown new Exception('an error');
一個(gè)例子:
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' );
}
[/code]
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 ) //試圖直接 將異常對(duì)象當(dāng)作字符串使用時(shí)調(diào)用子函數(shù)的返回值
final private void __clone ( void ) //克隆異常對(duì)象時(shí)調(diào)用
}
擴(kuò)展異常類
try-catch 可以有多個(gè) catch 子句,從第一個(gè) catch 子句開始,如果子句內(nèi)的 異常變量 類型匹配 thrown 語(yǔ)句拋出的異常類型,則該子句會(huì)被執(zhí)行而不再執(zhí)行其他catch子句,否則繼續(xù)嘗試下一個(gè) catch 子句,由于Exception 是所有 異常類的基類,因此拋出的異常都會(huì)與他匹配 ,如果你像個(gè)根據(jù)不同異常類型使用不同的處理方法,應(yīng)該將 Exception 類型的 catch 子句放到最后。
Exception 是所有異常的基類,可以根據(jù)實(shí)際需要擴(kuò)展異常類,
calss MyException extends Exception{
public errType = 'default';
public function __construct($errType=''){
$this->errType = $errType;
}
}
thrown new MyException (); //拋出一個(gè)異常
try{
// you codes that maybe cause an error
}catch(MyException $err){ // 這個(gè)錯(cuò)誤對(duì)象需要聲明類型
echo $err->errType();
}catch(ErrorException $err){ //ErrorException 是 PHP 5 增加的異常類,繼承于 Exception
echo 'error !';
}catch(Exception $err){
redirect('/error.php');
}
你可能會(huì)在 catch 子句中判斷異常的類型,或者根據(jù) code 等信息來(lái)決定是否處理異常,如果你卸載 catch 子句的代碼無(wú)法適當(dāng)?shù)奶幚聿东@的異常,你可以在 catch 子句內(nèi)繼續(xù) 拋出異常。
三、Exception 異常的回調(diào)函數(shù)
set_exception_handler(callback functionName) //發(fā)生 Exception 或其 子類的 異常是會(huì)調(diào)用此函數(shù)
function exceptionHandlerFun($errObj){ // Exception 異常的回調(diào)函數(shù) 只有一個(gè)參數(shù),就是拋出的異常對(duì)象。
//.......
}
Exception 異常的回調(diào)函數(shù)并不能像 set_error_handler 的回調(diào)函數(shù)那樣通過(guò)返回 true 來(lái)使異常被消除,即使回調(diào)函數(shù)處理了異常,后繼代碼也不會(huì)被繼續(xù)執(zhí)行,因此想繼續(xù)執(zhí)行后續(xù)代碼必須使用 try-catch。
但是有一個(gè)例外:腳本結(jié)束回調(diào)函數(shù)可以被執(zhí)行,拋出的異常即使沒(méi)有被處理,該回調(diào)函數(shù)也是能被執(zhí)行的。
register_shutdown_function(callback functionName[,argument1,argument2,...]);
例如:
function shutdownfunction(){
echo 'script is end';
}
register_shutdown_function("shutdownfunction");
因?yàn)?shutdownfunction() 在腳本結(jié)束時(shí)被執(zhí)行,所以 這個(gè)回調(diào)函數(shù)之內(nèi)可以調(diào)用腳本中任意位置的函數(shù),即使該函數(shù)定義在 錯(cuò)誤拋出位置之后(函數(shù)定義是在 腳本編譯期完成的)。
四、trigger_error(string errorMsg[,int user_error_type])
該函數(shù)用于主動(dòng)觸發(fā)一個(gè)錯(cuò)誤: 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è)置一個(gè)回調(diào)函數(shù)來(lái)處理錯(cuò)誤,包括系統(tǒng)拋出的錯(cuò)誤和用戶使用 trigger_error() 函數(shù)觸發(fā)的錯(cuò)誤。
可選參數(shù) user_error_type :
如果設(shè)定此參數(shù),則 trigger_error 拋出的錯(cuò)誤類型符合 在user_error_type 的定義范圍才能觸發(fā)回調(diào)函數(shù)。
這個(gè)值的設(shè)置類似于 error_reporting() 函數(shù) 。
第一個(gè)參數(shù)(callbeck functionName):
一個(gè)函數(shù)名,該函數(shù) 可以有 5 個(gè)參數(shù),其中前 2 個(gè)必選,依次是:
trigger_error 拋出的 user_error_type、trigger_error 拋出的 errorMsg、拋出錯(cuò)誤的文件的絕對(duì)路勁、拋出錯(cuò)誤的行號(hào)、拋出錯(cuò)誤時(shí)的上下文環(huán)境 (一個(gè)數(shù)組,包含了trigger_error() 所在作用域內(nèi)的所有變量、函數(shù)、類等數(shù)據(jù) )
回調(diào)函數(shù)的返回值: 如果返回 false ,系統(tǒng)錯(cuò)誤處理機(jī)制仍然繼續(xù)拋出該錯(cuò)誤,返回 true 或 無(wú)返回值 則消除錯(cuò)誤。
trigger_error() 觸發(fā)的錯(cuò)誤不會(huì)被 try-catch 異常捕獲語(yǔ)句捕獲。
PHP 5 添加了類似于其它語(yǔ)言的異常處理模塊。在 PHP 代碼中所產(chǎn)生的異常可被 throw 語(yǔ)句拋出并被 catch 語(yǔ)句捕獲。需要進(jìn)行異常處理的代碼都必須放入 try 代碼塊內(nèi),以便捕獲可能存在的異常。每一個(gè) try 至少要有一個(gè)與之對(duì)應(yīng)的 catch。使用多個(gè) catch 可以捕獲不同的類所產(chǎn)生的異常。當(dāng) try 代碼塊不再拋出異?;蛘哒也坏?catch 能匹配所拋出的異常時(shí),PHP 代碼就會(huì)在跳轉(zhuǎn)到最后一個(gè) catch 的后面繼續(xù)執(zhí)行。當(dāng)然,PHP 允許在 catch 代碼塊內(nèi)再次拋出(throw)異常。
當(dāng)一個(gè)異常被拋出時(shí),其后(譯者注:指拋出異常時(shí)所在的代碼塊)的代碼將不會(huì)繼續(xù)執(zhí)行,而 PHP 就會(huì)嘗試查找第一個(gè)能與之匹配的 catch。如果一個(gè)異常沒(méi)有被捕獲,而且又沒(méi)用使用 set_exception_handler() 作相應(yīng)的處理的話,那么 PHP 將會(huì)產(chǎn)生一個(gè)嚴(yán)重的錯(cuò)誤,并且輸出 Uncaught Exception ... (未捕獲異常)的提示信息。
當(dāng)異常被觸發(fā)時(shí),通常會(huì)發(fā)生:
•當(dāng)前代碼狀態(tài)被保存
•代碼執(zhí)行被切換到預(yù)定義的異常處理器函數(shù)
•根據(jù)情況,處理器也許會(huì)從保存的代碼狀態(tài)重新開始執(zhí)行代碼,終止腳本執(zhí)行,或從代碼中另外的位置繼續(xù)執(zhí)行腳本
一、錯(cuò)誤、異常 等級(jí)常量表
error:不能在編譯期發(fā)現(xiàn)的運(yùn)行期錯(cuò)誤,不如試圖用 echo 輸出一個(gè)未賦值的變量,這類問(wèn)題往往導(dǎo)致程序或邏輯無(wú)法繼續(xù)下去而需要中斷;
exception:程序執(zhí)行過(guò)程中出現(xiàn)意料之外的情況,邏輯上往往是行得通的,但不符合應(yīng)用場(chǎng)景,比如接收到一個(gè)長(zhǎng)度長(zhǎng)錯(cuò)預(yù)定格式的用戶命名,因此,異常主要靠編碼人員做預(yù)先做判斷后拋出,捕獲異常后改變程序流程來(lái)處理這些情況,不必中斷程序。
PHP 對(duì)于異常和錯(cuò)誤的界定似乎不是很明顯,尤其是低版本的PHP。
錯(cuò)誤和日志記錄值 常量 說(shuō)明 備注
1 E_ERROR (integer)
致命的運(yùn)行時(shí)錯(cuò)誤。這類錯(cuò)誤一般是不可恢復(fù)的情況,例如內(nèi)存分配導(dǎo)致的問(wèn)題。后果是導(dǎo)致腳本終止不再繼續(xù)運(yùn)行。
2 E_WARNING (integer)
運(yùn)行時(shí)警告 (非致命錯(cuò)誤)。僅給出提示信息,但是腳本不會(huì)終止運(yùn)行。
4 E_PARSE (integer)
編譯時(shí)語(yǔ)法解析錯(cuò)誤。解析錯(cuò)誤僅僅由分析器產(chǎn)生。
8 E_NOTICE (integer)
運(yùn)行時(shí)通知。表示腳本遇到可能會(huì)表現(xiàn)為錯(cuò)誤的情況,但是在可以正常運(yùn)行的腳本里面也可能會(huì)有類似的通知。
16 E_CORE_ERROR(integer)
在PHP初始化啟動(dòng)過(guò)程中發(fā)生的致命錯(cuò)誤。該錯(cuò)誤類似 E_ERROR,但是是由PHP引擎核心產(chǎn)生的。 since PHP 4
32 E_CORE_WARNING(integer)
PHP初始化啟動(dòng)過(guò)程中發(fā)生的警告 (非致命錯(cuò)誤) 。類似 E_WARNING,但是是由PHP引擎核心產(chǎn)生的。 since PHP 4
64 E_COMPILE_ERROR(integer)
致命編譯時(shí)錯(cuò)誤。類似E_ERROR, 但是是由Zend腳本引擎產(chǎn)生的。 since PHP 4
128 E_COMPILE_WARNING(integer)
編譯時(shí)警告 (非致命錯(cuò)誤)。類似 E_WARNING,但是是由Zend腳本引擎產(chǎn)生的。 since PHP 4
256 E_USER_ERROR(integer)
用戶產(chǎn)生的錯(cuò)誤信息。類似 E_ERROR, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 since PHP 4
512 E_USER_WARNING(integer)
用戶產(chǎn)生的警告信息。類似 E_WARNING, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 since PHP 4
1024 E_USER_NOTICE(integer)
用戶產(chǎn)生的通知信息。類似 E_NOTICE, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 since PHP 4
2048 E_STRICT (integer)
啟用 PHP 對(duì)代碼的修改建議,以確保代碼具有最佳的互操作性和向前兼容性。 since PHP 5
4096 E_RECOVERABLE_ERROR(integer)
可被捕捉的致命錯(cuò)誤。 它表示發(fā)生了一個(gè)可能非常危險(xiǎn)的錯(cuò)誤,但是還沒(méi)有導(dǎo)致PHP引擎處于不穩(wěn)定的狀態(tài)。 如果該錯(cuò)誤沒(méi)有被用戶自定義句柄捕獲 (參見 set_error_handler()),將成為一個(gè) E_ERROR 從而腳本會(huì)終止運(yùn)行。 since PHP 5.2.0
8192 E_DEPRECATED(integer)
運(yùn)行時(shí)通知。啟用后將會(huì)對(duì)在未來(lái)版本中可能無(wú)法正常工作的代碼給出警告。 since PHP 5.3.0
16384 E_USER_DEPRECATED(integer)
用戶產(chǎn)少的警告信息。 類似 E_DEPRECATED, 但是是由用戶自己在代碼中使用PHP函數(shù) trigger_error()來(lái)產(chǎn)生的。 since PHP 5.3.0
30719 E_ALL (integer)
E_STRICT出外的所有錯(cuò)誤和警告信息。 30719 in PHP 5.3.x, 6143 in PHP 5.2.x, 2047 previously
二、error_reporting() 及 try-catch、thrown
error_reporting() 函數(shù)可以獲取(不傳參時(shí))、設(shè)定腳本處理哪些異常(并非所有異常都需要處理,例如 E_CORE_WARNING、E_NOTICE、E_DEPRECATED 是可以忽略的),該設(shè)定將覆蓋 php.ini 中 error_reporting選項(xiàng)定義的異常處理設(shè)定。
例如:
error_reporting(E_ALL&~E_NOTICE) ; // 除了E_NOTICE其他異常都會(huì)被觸發(fā)(E_ALL&~E_NOTICE的二進(jìn)制運(yùn)算結(jié)果是:E_NOTICE對(duì)應(yīng)位的值被設(shè)置為0)try-catch 無(wú)法在類的自動(dòng)加載函數(shù) __autoload() 內(nèi)生效。
try-catch 無(wú)法用于捕獲異常,無(wú)法捕獲錯(cuò)誤,例如 trigger_error() 觸發(fā)的錯(cuò)誤,異常和錯(cuò)誤是不一樣的。
復(fù)制代碼 代碼如下:
try{
// you codes that maybe cause an error
}catch(Exception $err){ // 這個(gè)錯(cuò)誤對(duì)象需要聲明類型, Exception 是系統(tǒng)默認(rèn)異常處理類
echo $err->getMessage();
}
//thrown 可以拋出一個(gè)異常,如:
thrown new Exception('an error');
一個(gè)例子:
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' );
}
[/code]
Exception 類的結(jié)構(gòu):其中大部分方法都是 禁止改寫的(final )
復(fù)制代碼 代碼如下:
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 ) //試圖直接 將異常對(duì)象當(dāng)作字符串使用時(shí)調(diào)用子函數(shù)的返回值
final private void __clone ( void ) //克隆異常對(duì)象時(shí)調(diào)用
}
擴(kuò)展異常類
try-catch 可以有多個(gè) catch 子句,從第一個(gè) catch 子句開始,如果子句內(nèi)的 異常變量 類型匹配 thrown 語(yǔ)句拋出的異常類型,則該子句會(huì)被執(zhí)行而不再執(zhí)行其他catch子句,否則繼續(xù)嘗試下一個(gè) catch 子句,由于Exception 是所有 異常類的基類,因此拋出的異常都會(huì)與他匹配 ,如果你像個(gè)根據(jù)不同異常類型使用不同的處理方法,應(yīng)該將 Exception 類型的 catch 子句放到最后。
Exception 是所有異常的基類,可以根據(jù)實(shí)際需要擴(kuò)展異常類,
復(fù)制代碼 代碼如下:
calss MyException extends Exception{
public errType = 'default';
public function __construct($errType=''){
$this->errType = $errType;
}
}
thrown new MyException (); //拋出一個(gè)異常
try{
// you codes that maybe cause an error
}catch(MyException $err){ // 這個(gè)錯(cuò)誤對(duì)象需要聲明類型
echo $err->errType();
}catch(ErrorException $err){ //ErrorException 是 PHP 5 增加的異常類,繼承于 Exception
echo 'error !';
}catch(Exception $err){
redirect('/error.php');
}
你可能會(huì)在 catch 子句中判斷異常的類型,或者根據(jù) code 等信息來(lái)決定是否處理異常,如果你卸載 catch 子句的代碼無(wú)法適當(dāng)?shù)奶幚聿东@的異常,你可以在 catch 子句內(nèi)繼續(xù) 拋出異常。
三、Exception 異常的回調(diào)函數(shù)
復(fù)制代碼 代碼如下:
set_exception_handler(callback functionName) //發(fā)生 Exception 或其 子類的 異常是會(huì)調(diào)用此函數(shù)
function exceptionHandlerFun($errObj){ // Exception 異常的回調(diào)函數(shù) 只有一個(gè)參數(shù),就是拋出的異常對(duì)象。
//.......
}
Exception 異常的回調(diào)函數(shù)并不能像 set_error_handler 的回調(diào)函數(shù)那樣通過(guò)返回 true 來(lái)使異常被消除,即使回調(diào)函數(shù)處理了異常,后繼代碼也不會(huì)被繼續(xù)執(zhí)行,因此想繼續(xù)執(zhí)行后續(xù)代碼必須使用 try-catch。
但是有一個(gè)例外:腳本結(jié)束回調(diào)函數(shù)可以被執(zhí)行,拋出的異常即使沒(méi)有被處理,該回調(diào)函數(shù)也是能被執(zhí)行的。
register_shutdown_function(callback functionName[,argument1,argument2,...]);
例如:
復(fù)制代碼 代碼如下:
function shutdownfunction(){
echo 'script is end';
}
register_shutdown_function("shutdownfunction");
因?yàn)?shutdownfunction() 在腳本結(jié)束時(shí)被執(zhí)行,所以 這個(gè)回調(diào)函數(shù)之內(nèi)可以調(diào)用腳本中任意位置的函數(shù),即使該函數(shù)定義在 錯(cuò)誤拋出位置之后(函數(shù)定義是在 腳本編譯期完成的)。
四、trigger_error(string errorMsg[,int user_error_type])
該函數(shù)用于主動(dòng)觸發(fā)一個(gè)錯(cuò)誤: 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è)置一個(gè)回調(diào)函數(shù)來(lái)處理錯(cuò)誤,包括系統(tǒng)拋出的錯(cuò)誤和用戶使用 trigger_error() 函數(shù)觸發(fā)的錯(cuò)誤。
可選參數(shù) user_error_type :
如果設(shè)定此參數(shù),則 trigger_error 拋出的錯(cuò)誤類型符合 在user_error_type 的定義范圍才能觸發(fā)回調(diào)函數(shù)。
這個(gè)值的設(shè)置類似于 error_reporting() 函數(shù) 。
第一個(gè)參數(shù)(callbeck functionName):
一個(gè)函數(shù)名,該函數(shù) 可以有 5 個(gè)參數(shù),其中前 2 個(gè)必選,依次是:
trigger_error 拋出的 user_error_type、trigger_error 拋出的 errorMsg、拋出錯(cuò)誤的文件的絕對(duì)路勁、拋出錯(cuò)誤的行號(hào)、拋出錯(cuò)誤時(shí)的上下文環(huán)境 (一個(gè)數(shù)組,包含了trigger_error() 所在作用域內(nèi)的所有變量、函數(shù)、類等數(shù)據(jù) )
回調(diào)函數(shù)的返回值: 如果返回 false ,系統(tǒng)錯(cuò)誤處理機(jī)制仍然繼續(xù)拋出該錯(cuò)誤,返回 true 或 無(wú)返回值 則消除錯(cuò)誤。
trigger_error() 觸發(fā)的錯(cuò)誤不會(huì)被 try-catch 異常捕獲語(yǔ)句捕獲。
相關(guān)文章
用PHP實(shí)現(xiàn)的隨機(jī)廣告顯示代碼
用PHP實(shí)現(xiàn)的隨機(jī)廣告顯示代碼...2007-06-06PHPExcel導(dǎo)出2003和2007的excel文檔功能示例
這篇文章主要介紹了PHPExcel導(dǎo)出2003和2007的excel文檔功能,結(jié)合實(shí)例形式分析了PHPExcel屬性設(shè)置及文檔導(dǎo)出操作相關(guān)技巧,需要的朋友可以參考下2017-01-01php版本CKEditor 4和CKFinder安裝及配置方法圖文教程
這篇文章主要介紹了php版本CKEditor 4和CKFinder安裝及配置方法,結(jié)合圖文與實(shí)例形式詳細(xì)分析了php安裝及配置CKEditor 4和CKFinder相關(guān)實(shí)現(xiàn)步驟、操作技巧與注意事項(xiàng),需要的朋友可以參考下2019-06-06PHP set_error_handler()函數(shù)使用詳解(示例)
本文詳細(xì)介紹PHP set_error_handler()函數(shù)的使用方法,最后還提供了一個(gè)實(shí)例2013-11-11php htmlspecialchars()與shtmlspecialchars()函數(shù)的深入分析
本篇文章是對(duì)php中的htmlspecialchars()與shtmlspecialchars() 函數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06PHP簡(jiǎn)單判斷iPhone、iPad、Android及PC設(shè)備的方法
這篇文章主要介紹了PHP簡(jiǎn)單判斷iPhone、iPad、Android及PC設(shè)備的方法,可有效的判斷出移動(dòng)設(shè)備與PC端類型,需要的朋友可以參考下2016-10-10