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