phpiftry
㈠ php中為什麼不用if代替try
這是兩個 東西好咩
try 是處理異常的 可以結合 throw 及時拋出異常,然後提前結束某個方法 然後提交給catch捕獲。最後還可以finally 做內存、資源釋放工作
舉個栗子
比如判斷 post來的數據 是否合法
你可以用if 判斷 $_POST 然後 不合法的話 可以exit掉php腳本
但是 用try 再鑲嵌 if判斷 再加throw拋出異常, 不但可以 集中在catch中處理這些錯誤,更可以根據你自定義的異常等級 有不同的處理方式。
寫 高度集成的類的時候 try catch 非常好用。 就是因為他 可以 拋出 Expection 類。
另外 if 是根據你的 後面表達式的 真假 來執行內部 流程式控制制
而try 僅僅是發生異常的時候 廢棄掉try {}中的過程體 再在catch中捕獲這些異常。
或者自己用throw強行拋出異常 也可以,同時也會終止掉try的過程體
至於你自己是否拋出自定義的異常,到時可選的。
詳細請參閱php手冊 異常處理章節。
㈡ PHP 的 try.catch 會不會影響程序的執行效率
try..catch是異常處理機制,為防止程序體系的崩潰提供了一個很好的防禦手段。
異常處理代碼對於程序的執行效率是有一定影響的,所以通常建議是不要濫用,更不應以異常處理來代替 if..else。
更進一步的影響程序執行效率的數據,在網上有提供了一個簡單的測試代碼:
作者:金正
<?php
if($argc!==3||
!in_array($argv[1],array('try','return'))||
(int)$argv[2]<1){
exit(1);
}
$method=$argv[1];
$cnt=(int)$argv[2];
functionmTryFunc(){
thrownewException('test');
}
functionmReturnFunc(){
returnarray(
'err_no'=>-1,
'err_msg'=>'test',
);
}
functionerrorFunc($str){
}
functionmTry($cnt){
for($i=0;$i<$cnt;$i++){
try{
mTryFunc();
}
catch(Exception$e){
errorFunc($e->getMessage());
}
}
}
functionmReturn($cnt){
for($i=0;$i<$cnt;$i++){
$ret=mReturnFunc();
if($ret['err_no']!=0){
errorFunc($ret['err_msg']);
}
}
}
$timeStart=microtime(true);
switch($method){
case'try':
mTry($cnt);
break;
case'return':
mReturn($cnt);
break;
default:
exit(1);
}
$timeEnd=microtime(true);
$result=$timeEnd-$timeStart;
echo"Method:$methodCycle:$cntCost:$result ";
exit(0);
㈢ 如何處理 PHP 的錯誤與異常
首先要知道什麼是PHP異常?
異常(Exception)用於在指定的錯誤發生時改變腳本的正常流程。
PHP 5 提供了一種新的面向對象的錯誤處理方法。
異常處理用於在指定的錯誤(異常)情況發生時改變腳本的正常流程。這種情況稱為異常。
當異常被觸發時,通常會發生:
當前代碼狀態被保存
代碼執行被切換到預定義的異常處理器函數
根據情況,處理器也許會從保存的代碼狀態重新開始執行代碼,終止腳本執行,或從代碼中另外的位置繼續執行腳本
我們將展示不同的錯誤處理方法:
異常的基本使用
創建自定義的異常處理器
多個異常
重新拋出異常
設置頂層異常處理器
異常的基本使用
當異常被拋出時,其後的代碼不會繼續執行,PHP 會嘗試查找匹配的 「catch」 代碼塊。
如果異常沒有被捕獲,而且又沒用使用 set_exception_handler() 作相應的處理的話,那麼將發生一個嚴重的錯誤(致命錯誤),並且輸出 「Uncaught Exception」 (未捕獲異常)的錯誤消息。
讓我們嘗試拋出一個異常,同時不去捕獲它:
復制代碼代碼如下:
<?php
//create function with an exceptionfunction
checkNum($number) {
if($number>1) {
throw new Exception(」Value must be 1 or below」);
} return true;
}
//trigger
exceptioncheckNum(2);
?>
上面的代碼會獲得類似這樣的一個錯誤:
Fatal error: Uncaught exception 『Exception' with message 『Value must be 1 or below' in C:\webfolder\test.php:6 Stack trace: #0 C:\webfolder\test.php(12): checkNum(28) #1 {main} thrown in C:\webfolder\test.php on line 6
Try, throw 和 catch
要避免上面例子出現的錯誤,我們需要創建適當的代碼來處理異常。
處理處理程序應當包括:
Try - 使用異常的函數應該位於 「try」 代碼塊內。如果沒有觸發異常,則代碼將照常繼續執行。但是如果異常被觸發,會拋出一個異常。
Throw - 這里規定如何觸發異常。每一個 「throw」 必須對應至少一個 「catch」
Catch - 「catch」 代碼塊會捕獲異常,並創建一個包含異常信息的對象
讓我們觸發一個異常:
<?php//創建可拋出一個異常的函數function checkNum($number) { if($number>1) { throw new Exception(」Value must be 1 or below」); } return true; }//在 「try」 代碼塊中觸發異常try { checkNum(2); //If the exception is thrown, this text will not be shown echo 『If you see this, the number is 1 or below'; }//捕獲異常catch(Exception $e) { echo 『Message: 『 .$e->getMessage(); }?>
上面代碼將獲得類似這樣一個錯誤:
Message: Value must be 1 or below
例子解釋:
上面的代碼拋出了一個異常,並捕獲了它:
創建 checkNum() 函數。它檢測數字是否大於 1。如果是,則拋出一個異常。
在 「try」 代碼塊中調用 checkNum() 函數。
checkNum() 函數中的異常被拋出
「catch」 代碼塊接收到該異常,並創建一個包含異常信息的對象 ($e)。
通過從這個 exception 對象調用 $e->getMessage(),輸出來自該異常的錯誤消息
不過,為了遵循「每個 throw 必須對應一個 catch」的原則,可以設置一個頂層的異常處理器來處理漏掉的錯誤。
創建一個自定義的 Exception 類
創建自定義的異常處理程序非常簡單。我們簡單地創建了一個專門的類,當 PHP 中發生異常時,可調用其函數。該類必須是 exception 類的一個擴展。
這個自定義的 exception 類繼承了 PHP 的 exception 類的所有屬性,您可向其添加自定義的函數。
我們開始創建 exception 類:
復制代碼代碼如下:
<?php
class customException extends Exception {
public function errorMessage() {
//error message
$errorMsg = 『Error on line 『.$this->getLine().' in 『.$this->getFile() .': <b>'.$this->getMessage().'</b> is not a valid E-Mail address'; return $errorMsg;
}
}
$email = 「someone@example…com」;try {
//check if
if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE) {
//throw exception if email is not valid throw
new customException($email);
}
}catch (customException $e)
{
//display custom message
echo $e->errorMessage();
}?>
這個新的類是舊的 exception 類的副本,外加 errorMessage() 函數。正因為它是舊類的副本,因此它從舊類繼承了屬性和方法,我們可以使用 exception 類的方法,比如 getLine() 、 getFile() 以及 getMessage()。
例子解釋:
上面的代碼拋出了一個異常,並通過一個自定義的 exception 類來捕獲它:
customException() 類是作為舊的 exception 類的一個擴展來創建的。這樣它就繼承了舊類的所有屬性和方法。
創建 errorMessage() 函數。如果 e-mail 地址不合法,則該函數返回一條錯誤消息
把 $email 變數設置為不合法的 e-mail 地址字元串
執行 「try」 代碼塊,由於 e-mail 地址不合法,因此拋出一個異常
「catch」 代碼塊捕獲異常,並顯示錯誤消息
多個異常
可以為一段腳本使用多個異常,來檢測多種情況。
可以使用多個 if..else 代碼塊,或一個 switch 代碼塊,或者嵌套多個異常。這些異常能夠使用不同的 exception 類,並返回不同的錯誤消息:
復制代碼代碼如下:
<?php
class customException extends Exception{public function errorMessage(){
//error
message$errorMsg = 『Error on line 『.$this->getLine().' in 『.$this->getFile().': <b>'.$this->getMessage().'</b> is not a valid E-Mail address';
return $errorMsg;
}
}
$email = 「[email protected]」;try {
//check if
if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE) {
//throw exception if email is not valid throw new
customException($email);
}
//check for 「example」 in mail address
if(strpos($email, 「example」) !== FALSE) { throw new Exception(」$email is an example e-mail」); } }catch (customException $e) { echo $e->errorMessage(); }catch(Exception $e) { echo $e->getMessage(); }?>
例子解釋:
上面的代碼測試了兩種條件,如何任何條件不成立,則拋出一個異常:
customException() 類是作為舊的 exception 類的一個擴展來創建的。這樣它就繼承了舊類的所有屬性和方法。
創建 errorMessage() 函數。如果 e-mail 地址不合法,則該函數返回一個錯誤消息。
執行 「try」 代碼塊,在第一個條件下,不會拋出異常。
由於 e-mail 含有字元串 「example」,第二個條件會觸發異常。
「catch」 代碼塊會捕獲異常,並顯示恰當的錯誤消息
如果沒有捕獲 customException,緊緊捕獲了 base exception,則在那裡處理異常。
重新拋出異常
有時,當異常被拋出時,您也許希望以不同於標準的方式對它進行處理。可以在一個 「catch」 代碼塊中再次拋出異常。
腳本應該對用戶隱藏系統錯誤。對程序員來說,系統錯誤也許很重要,但是用戶對它們並不感興趣。為了讓用戶更容易使用,您可以再次拋出帶有對用戶比較友好的消息的異常:
復制代碼代碼如下:
<?php
class customException extends Exception { public function errorMessage() {
//error message
$errorMsg = $this->getMessage().' is not a valid E-Mail address.'; return $errorMsg; } }$email = 「[email protected]」;try { try {
//check for 「example」 in mail address
if(strpos($email, 「example」) !== FALSE) {
//throw exception if email is not valid throw new
Exception($email); } } catch(Exception $e) {
//re-throw exception throw new
customException($email); } }catch (customException $e) {
//display custom message
echo $e->errorMessage(); }
?>
例子解釋:
上面的代碼檢測在郵件地址中是否含有字元串 「example」。如果有,則再次拋出異常:
customException() 類是作為舊的 exception 類的一個擴展來創建的。這樣它就繼承了舊類的所有屬性和方法。
創建 errorMessage() 函數。如果 e-mail 地址不合法,則該函數返回一個錯誤消息。
把 $email 變數設置為一個有效的郵件地址,但含有字元串 「example」。
「try」 代碼塊包含另一個 「try」 代碼塊,這樣就可以再次拋出異常。
由於 e-mail 包含字元串 「example」,因此觸發異常。
「catch」 捕獲到該異常,並重新拋出 「customException」。
捕獲到 「customException」,並顯示一條錯誤消息。
如果在其目前的 「try」 代碼塊中異常沒有被捕獲,則它將在更高層級上查找 catch 代碼塊。
設置頂層異常處理器 (Top Level Exception Handler)
set_exception_handler() 函數可設置處理所有未捕獲異常的用戶定義函數。
復制代碼代碼如下:
<?php
function myException($exception){
echo 「<b>Exception:</b> 」 , $exception->getMessage();
}
set_exception_handler('myException');
throw new Exception('Uncaught Exception occurred');
?>
以上代碼的輸出應該類似這樣:
Exception: Uncaught Exception occurred
在上面的代碼中,不存在 「catch」 代碼塊,而是觸發頂層的異常處理程序。應該使用此函數來捕獲所有未被捕獲的異常。
異常的規則
需要進行異常處理的代碼應該放入 try 代碼塊內,以便捕獲潛在的異常。
每個 try 或 throw 代碼塊必須至少擁有一個對應的 catch 代碼塊。
使用多個 catch 代碼塊可以捕獲不同種類的異常。
可以在 try 代碼塊內的 catch 代碼塊中再次拋出(re-thrown)異常。
簡而言之:如果拋出了異常,就必須捕獲它。
㈣ PHP中處理異常有幾種方式請詳述
php中異常處理方法總結:
當異常被觸發時,通常會發生:
在PHP5中添加了類似於其它語言的錯誤異常處理模塊。在 PHP代碼中所產生的異常可被 throw語句拋出並被 catch 語句捕獲。需要進行異常處理的代碼都必須放入 try 代碼塊內,以便捕獲可能存在的異常。每一個 try 至少要有一個與之對應的 catch。使用多個 catch 可以捕獲不同的類所產生的異常。當 try 代碼塊不再拋出異常或者找不到 catch 能匹配所拋出的異常時,PHP 代碼就會在跳轉到最後一個 catch 的後面繼續執行。當然,PHP 允許在 catch 代碼塊內再次拋出(throw)異常。當一個異常被拋出時,其後(譯者註:指拋出異常時所在的代碼塊)的代碼將不會繼續執行,而 PHP 就會嘗試查找第一個能與之匹配的 catch。如果一個異常沒有被捕獲,而且又沒用使用 set_exception_handler() 作相應的處理的話,那麼 PHP 將會產生一個嚴重的錯誤,並且輸出 Uncaught Exception ... (未捕獲異常)的提示信息。
1、異常類的層級關系:
代碼如下 復制代碼
class NotFoundException extends Exception{}
class InputException extends Exception{}
class DBException extends Exception{}
2、配置未捕捉異常的處理器:
代碼如下 復制代碼
function exception_uncaught_handler(Exception $e) {
header('Content-type:text/html; charset=utf-8');
if ($e instanceof NotFoundException)
exit($e->getMessage());
elseif ($e instanceof DBException)
exit($e->getMessage());
else
exit($e->getMessage());
}
set_exception_handler('exception_uncaught_handler');
3、在資料庫連接代碼,手動拋出DBException異常但未使用try…catch進行捕獲處理,該異常將被PHP自定義異常處理器
代碼如下 復制代碼
exception_uncaught_handler()函數處理:
$this->resConn = mysql_connect ($CONFIGS['db_host'], $CONFIGS['db_user'], $CONFIGS['db_pwd']);
if (false == is_resource($this->resConn))
throw new DBException('資料庫連接失敗。'.mysql_error($this->resConn));
4、業務邏輯一瞥:
if (0 != strcmp($curAlbum->interest_id, $it))
throw new NotFoundException('很抱歉,你所訪問的相冊不存在');
以上就是PHP自定義異常處理器的具體使用方法
實例
代碼如下 復制代碼
<?php
class customException extends Exception
{
public function errorMessage()
{
//error message
$errorMsg = 'Error on line '.$this->getLine().' in '.$this->getFile()
.': <b>'.$this->getMessage().'</b> is not a valid E-Mail address';
return $errorMsg;
}
}
$email = "[email protected]";
try
{
//check if
if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE)
{
//throw exception if email is not valid
throw new customException($email);
}
//check for "example" in mail address
if(strpos($email, "example") !== FALSE)
{
throw new Exception("$email is an example e-mail");
}
}
catch (customException $e)
{
echo $e->errorMessage();
}
catch(Exception $e)
{
echo $e->getMessage();
}
?>
例子解釋:
上面的代碼測試了兩種條件,如何任何條件不成立,則拋出一個異常:
1.customException() 類是作為舊的 exception 類的一個擴展來創建的。這樣它就繼承了舊類的所有屬性和方法。
2.創建 errorMessage() 函數。如果 e-mail 地址不合法,則該函數返回一個錯誤消息。
3.執行 "try" 代碼塊,在第一個條件下,不會拋出異常。
4.由於 e-mail 含有字元串 "example",第二個條件會觸發異常。
5."catch" 代碼塊會捕獲異常,並顯示恰當的錯誤消息
如果沒有捕獲 customException,緊緊捕獲了 base exception,則在那裡處理異常。
重新拋出異常
有時,當異常被拋出時,您也許希望以不同於標準的方式對它進行處理。可以在一個 "catch" 代碼塊中再次拋出異常。
代碼如下 復制代碼
<?php
/*
*/
/*
* 總結:PHP異常的使用方法分三步:
* 第一步:定義異常類,如果不定義就用系統默認的異常類;
* 第二步:當出現異常時用 throw 拋出異常,例如 ex1($num2);異常的參數是$num2用該異常的getMessage()獲取;
* 第三步:觸發異常,用try子句,當滿足條件時 throw new ex1($num);
* 第四步:catch捕獲異常 catch (ex2 $e),相當於實例化一個定義好的異常類ex2為$e;
*
* 注意,異常可以定義多個,但是只能觸發一個,也就是說只能用catch捕獲一個異常
*/
//================基本異常類
//創建可拋出一個異常的函數
function num($num){
if ($num>1){//異常拋出條件
$msg=」數值不能大於1″;//異常提示信息
throw new Exception($msg);//拋出異常
}
echo 「數值小於1″;
}
//在 「try」 代碼塊中觸發異常
try {
num(3);
echo 「執行正常」;
}
//捕獲異常
catch (Exception $e){
echo 「錯誤信息:」.$e->getMessage();//Exception()的系統方法獲取異常信息
echo 「錯誤文件:」.$e->getFile();//Exception()的系統方法獲取異常文件名
echo 「行數:」.$e->getLine();//Exception()的系統方法獲取異常行數
}
//======================================================================
echo 「<br>========================================================<br>」;
//擴展基本異常類
function checkEmail($email){//定義一個可以拋出異常的判斷EMAIL合法性的函數
if (filter_var($email,FILTER_VALIDATE_EMAIL)==false){
throw new checkEmailException($email);//拋出異常用EMAIL做參數
}
echo 「郵件合法」;
}
class checkEmailException extends Exception{//定義擴展異常類
public function errormsg(){
$msg=」錯誤原因:」.$this->getMessage().」不是一個合法的EMAIL地址!」;
$msg.=」錯誤文件名:」.$this->getFile();
$msg.=」錯誤行數:」.$this->getLine();
echo $msg;
}
}
$email=」email…[email protected]「;
try {//觸發異常
checkEmail($email);
}
//捕獲異常
catch (checkEmailException $e){
$e->errormsg();
}
//==================================多個異常的捕獲
echo 「<br>===================================================<br>」;
class ex1 extends Exception{//定義一個異常類
public function msg(){
$msg=」錯誤原因:」.$this->getMessage().」大於100<br>」;
$msg.=」錯誤文件:」.$this->getFile().」<Br>」;
$msg.=」錯誤代碼:」.$this->getCode().」<br>」;
$msg.=」行數:」.$this->getLine().」<br>」;
echo $msg;
}
}
class ex2 extends Exception{//定義一個異常類
public function msg(){
$msg=」錯誤原因:」.$this->getMessage().」等於100<br>」;
$msg.=」錯誤文件:」.$this->getFile().」<Br>」;
$msg.=」行數:」.$this->getLine().」<br>」;
echo $msg;
}
}
$num2=100;
try {
if ($num2>100){//當條件滿足時觸發
throw new ex1($num2);
}
if ($num2==100){//當條件滿足時觸發
throw new ex2($num2);
}
}
catch (ex2 $e){//捕獲觸發的異常
$e->msg();
}
catch (ex1 $e){//捕獲觸發的異常
$e->msg();
}
/*
* 總結:PHP異常的使用方法分三步:
* 第一步:定義異常類,如果不定義就用系統默認的異常類;
* 第二步:當出現異常時用 throw 拋出異常,例如 ex1($num2);異常的參數是$num2用該異常的getMessage()獲取;
* 第三步:觸發異常,用try子句,當滿足條件時 throw new ex1($num);
* 第四步:catch捕獲異常 catch (ex2 $e),相當於實例化一個定義好的異常類ex2為$e;
*
* 注意,異常可以定義多個,但是只能觸發一個,也就是說只能用catch捕獲一個異常
*/
?>