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