php拋出異常與捕捉特定類型的異常詳解
什么是異常?
PHP 5 提供了一種新的面向?qū)ο蟮腻e(cuò)誤處理方法。
異常處理用于在指定的錯(cuò)誤(異常)情況發(fā)生時(shí)改變腳本的正常流程。這種情況稱為異常。
當(dāng)異常被觸發(fā)時(shí),通常會(huì)發(fā)生:
當(dāng)前代碼狀態(tài)被保存
代碼執(zhí)行被切換到預(yù)定義的異常處理器函數(shù)
根據(jù)情況,處理器也許會(huì)從保存的代碼狀態(tài)重新開(kāi)始執(zhí)行代碼,終止腳本執(zhí)行,或從代碼中另外的位置繼續(xù)執(zhí)行腳本
我們將展示不同的錯(cuò)誤處理方法:
異常的基本使用
創(chuàng)建自定義的異常處理器
多個(gè)異常
重新拋出異常
設(shè)置頂層異常處理器
php拋出異常與捕捉特定類型的異常最終的目的還是要給出對(duì)應(yīng)的解決辦法,讓代碼可以繼續(xù)運(yùn)行。
本文的測(cè)試環(huán)境:PHP5.5.36 Safari 9.1.2
1 <?php 2 header("content-type:text/html; charset=utf-8"); 3 /** 4 * 包裹重量異常 5 */ 6 class HeavyParcelException extends Exception {} 7 8 /** 9 * 包裹類 10 */ 11 class Parcel { 12 13 /** 14 * 包裹寄送目的地地址 15 */ 16 public $address; 17 18 /** 19 * 包裹重量 20 */ 21 public $weight; 22 } 23 24 /** 25 * 派送員 26 */ 27 class Courier { 28 29 /** 30 * 運(yùn)送 31 */ 32 public function ship(Parcel $parcel) { 33 //check we have an address 34 //如果包裹的目的地為空 35 if(empty($parcel->address)) { 36 throw new Exception('address not Specified(未填寫地址)!'); 37 } 38 39 //check the weight 40 //如果重量超過(guò)5 41 if($parcel->weight > 5) { 42 throw new HeavyParcelException('Parcel exceeds courier limit(包裹超過(guò)運(yùn)送上限)!'); 43 } 44 45 //otherwise we're coll 46 return true; 47 } 48 } 49 50 $myCourier = new Courier(); 51 $parcel = new Parcel(); 52 //add the address if we have it 為了測(cè)試這里不填寫地址 53 $parcel->weight = 7; 54 try { 55 $myCourier->ship($parcel); 56 echo "parcel shipped"; 57 } catch (HeavyParcelException $e) {//捕獲HeavyParcelException 不寫這個(gè)異常的類型名字,就跑到普通Exception拋出去了 58 echo "Parcel weight error(重量錯(cuò)誤): " . $e->getMessage(); 59 //redirect them to choose another courier 60 } catch (Exception $e) { 61 echo "Someting went wrong(地址錯(cuò)誤): " . $e->getMessage(); 62 //exit so we don't try to proceed any further 63 exit; 64 } 65 echo '<br/>'; 66 $a = 123; 67 echo $a;
從54行開(kāi)始的代碼執(zhí)行順序:
55 >
32 >
35(ship方法中先檢查的是地址為空,這里會(huì)拋出Exception
,而非57行的HeavyParcelException
) >
60(捕獲到Exception
) >
616263 輸出地址錯(cuò)誤 exit
;不會(huì)輸出65到67行了
Tips:
我感覺(jué)這一塊最重要的就是搞清楚代碼執(zhí)行的順序。寫幾段,然后改一改跑一跑。
1.捕獲的順序,要看try
中的代碼中throw
的是哪個(gè)類型的Exception
,然后才看 catch
里的順序。
2.57行的捕獲的是特定的類型HeavyParcelException
不能寫錯(cuò),或?qū)?code>Exception都會(huì)有問(wèn)題。可以自己試試。
1)例如地址不為空,57行寫成了HeavyParcelException111
,就會(huì),在60行它的父類對(duì)象中捕獲到,重量錯(cuò)誤。這不是我們想要的。
2)例如地址為空,57行寫成了Exception
,會(huì)拋出地址錯(cuò)誤,但捕獲的卻是本來(lái)負(fù)責(zé)重量的catch
。這也不是我們想要的。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
- PHP 的異常處理、錯(cuò)誤的拋出及回調(diào)函數(shù)等面向?qū)ο蟮腻e(cuò)誤處理方法
- PHP如何拋出異常處理錯(cuò)誤
- PHP異常Parse error: syntax error, unexpected T_VAR錯(cuò)誤解決方法
- php中try catch捕獲異常實(shí)例詳解
- PHP的異常處理類Exception的使用及說(shuō)明
- php Try Catch異常測(cè)試
- PHP中的錯(cuò)誤處理、異常處理機(jī)制分析
- php中異常處理方法小結(jié)
- php異常:Parse error: syntax error, unexpected T_ENCAPSED_AND_WHITESPACE eval()''d code error
- php更新mysql后獲取影響的行數(shù)發(fā)生異常解決方法
相關(guān)文章
PHP實(shí)現(xiàn)在數(shù)據(jù)庫(kù)百萬(wàn)條數(shù)據(jù)中隨機(jī)獲取20條記錄的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)在數(shù)據(jù)庫(kù)百萬(wàn)條數(shù)據(jù)中隨機(jī)獲取20條記錄的方法,涉及php簡(jiǎn)單數(shù)據(jù)庫(kù)查詢與隨機(jī)數(shù)操作相關(guān)技巧,需要的朋友可以參考下2017-04-04關(guān)于Laravel Service Provider開(kāi)發(fā)設(shè)置延遲加載時(shí)遇到的問(wèn)題詳解
這篇文章主要給大家介紹了關(guān)于Laravel Service Provider開(kāi)發(fā)設(shè)置延遲加載時(shí)遇到的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起看看吧。2018-01-01php+xml結(jié)合Ajax實(shí)現(xiàn)點(diǎn)贊功能完整實(shí)例
這篇文章主要介紹了php+xml結(jié)合Ajax實(shí)現(xiàn)點(diǎn)贊功能的方法,以一個(gè)完整實(shí)例形式詳細(xì)分析了XML文件、html頁(yè)面以及Ajax結(jié)合php實(shí)現(xiàn)點(diǎn)贊功能的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-01-01淺析使用Turck-mmcache編譯來(lái)加速、優(yōu)化PHP代碼
本篇文章是對(duì)使用Turck-mmcache編譯來(lái)加速、優(yōu)化PHP代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06深入解析fsockopen與pfsockopen的區(qū)別
本篇文章是對(duì)fsockopen與pfsockopen的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-07-07php使用curl獲取header檢測(cè)開(kāi)啟GZip壓縮的方法
這篇文章主要介紹了php使用curl獲取header檢測(cè)開(kāi)啟GZip壓縮的方法,結(jié)合實(shí)例形式總結(jié)分析了三種常見(jiàn)的header檢測(cè)方法并給出了使用curl檢測(cè)Gzip壓縮開(kāi)啟情況的方法,需要的朋友可以參考下2018-08-08