本文實例講述了php7 錯誤處理機制修改。分享給大家供大家參考,具體如下:
一、現在有兩個異常類:Exception and Error.
PHP7現在有兩個異常類,Exception and Error。這兩個類都實現了一個新的接口:Throwable。在您的異常處理代碼中,類型暗示可能需要調整下。
二、一些致命錯誤和可恢復致命錯誤改為拋出Error對象。
有一些致命錯誤和可恢復致命錯誤現在改為報出Error對象。Error對象是和Exception獨立的,它們無法被常規(guī)的try/catch撲獲。編者按:需要注冊錯誤處理函數,請參考下面的RFC。
對于這些已經轉為異常的可恢復致命錯誤,已經無法通過error handler靜默的忽略掉。尤其是無法忽略類型暗示錯誤。
三、語法錯誤會拋出一個ParseError對象
語法錯誤會拋出一個ParseError對象,該對象繼承自Error對象。之前處理eval()的時候,對于潛在可能錯誤的代碼除了檢查返回值或者error_get_last()之外,還應該捕獲ParseError對象。
四、內部對象的構造方法如果失敗的時候總會拋出異常
內部對象的構造方法如果失敗的時候總會報出異常。之前的有一些構造方法會返回NULL或者一個無法使用的對象。
五、一些E_STRICT錯誤的級別調整了。
PHP 7 錯誤處理
PHP 7 改變了大多數錯誤的報告方式。不同于 PHP 5 的傳統(tǒng)錯誤報告機制,現在大多數錯誤被作為 Error 異常拋出。
這種 Error 異??梢韵衿胀ó惓R粯颖?try / catch 塊所捕獲。如果沒有匹配的 try / catch 塊, 則調用異常處理函數(由 set_exception_handler() 注冊)進行處理。 如果尚未注冊異常處理函數,則按照傳統(tǒng)方式處理:被報告為一個致命錯誤(Fatal Error)。
Error 類并不是從 Exception 類 擴展出來的,所以用 catch (Exception $e) { ... } 這樣的代碼是捕獲不 到 Error 的。你可以用 catch (Error $e) { ... } 這樣的代碼,或者通過注冊異常處理函數( set_exception_handler())來捕獲 Error。
Error 異常層次結構
1.Error
-
ArithmeticError
-
AssertionError
-
DivisionByZeroError
-
ParseError
-
TypeError
2.Exception
...
![](/d/20211017/5c1756921226389ce2c6576ac8a34151.gif)
實例
?php c
lass MathOperations {
protected $n = 10; // 求余數運算,除數為 0,拋出異常
public function doOperation(): string {
try {
$value = $this->n % 0;
return $value;
} catch (DivisionByZeroError $e) {
return $e->getMessage();
}
} }
$mathOperationsObj = new MathOperations();
print($mathOperationsObj->doOperation());
?>
以上程序執(zhí)行輸出結果為:
PHP 7 異常
PHP 7 異常用于向下兼容及增強舊的assert()函數。它能在生產環(huán)境中實現零成本的斷言,并且提供拋出自定義異常及錯誤的能力。
老版本的API出于兼容目的將繼續(xù)被維護,assert()現在是一個語言結構,它允許第一個參數是一個表達式,而不僅僅是一個待計算的 string或一個待測試的boolean。
assert() 配置
配置項 |
默認值 |
可選值 |
zend.assertions |
1 |
|
assert.exception |
0 |
-
1 - 斷言失敗時拋出,可以拋出異常對象,如果沒有提供異常,則拋出 AssertionError 對象實例。
-
0 - 使用或生成 Throwable, 僅僅是基于對象生成的警告而不是拋出對象(與 PHP 5 兼容)
|
參數
assertion
斷言。在 PHP 5 中,是一個用于執(zhí)行的字符串或者用于測試的布爾值。在 PHP 7 中,可以是一個返回任何值的表達式, 它將被執(zhí)行結果用于指明斷言是否成功。
description
如果 assertion 失敗了,選項 description 將會包括在失敗信息里。
exception
在 PHP 7 中,第二個參數可以是一個 Throwable 對象,而不是一個字符串,如果斷言失敗且啟用了 assert.exception 該對象將被拋出。
實例
將 zend.assertions 設置為 0:
?php
ini_set('zend.assertions', 0);
assert(true == false);
echo 'Hi!';
?>
以上程序執(zhí)行輸出結果為:
Hi!
將 zend.assertions 設置為 1,assert.exception 設置為 1:
實例
?php
ini_set('zend.assertions', 1);
ini_set('assert.exception', 1);
assert(true == false); echo 'Hi!';
?>
以上程序執(zhí)行輸出結果為:
Fatal error: Uncaught AssertionError:
assert(true == false) in -:2Stack trace:#0 -(2):
assert(false, 'assert(true == ...')#1 {main}
thrown in - on line 2
更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP錯誤與異常處理方法總結》、《php字符串(string)用法總結》、《PHP數組(Array)操作技巧大全》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- MacOS下PHP7.1升級到PHP7.4.15的方法
- php7和php5具體區(qū)別實例講解
- PHP7原生MySQL數據庫操作實現代碼
- php7 參數、整形及字符串處理機制修改實例分析
- php7 list()、session及其他模塊的修改實例分析
- php5.6.x到php7.0.x特性小結
- PHP7.1實現的AES與RSA加密操作示例
- php7函數,聲明,返回值等新特性介紹
- 可兼容php5與php7的cURL文件上傳功能實例分析
- php7和php5的詳細對比