錯(cuò)誤處理機(jī)制修改
錯(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 class 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é)果為:
Modulo by zero
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 |
|
assert.exception | 0 |
|
參數(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