溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何修改php7 錯誤處理機(jī)制修改

發(fā)布時間:2021-03-08 15:30:47 來源:億速云 閱讀:152 作者:TREX 欄目:開發(fā)技術(shù)

這篇文章主要講解了“如何修改php7 錯誤處理機(jī)制修改”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“如何修改php7 錯誤處理機(jī)制修改”吧!

本文實(shí)例講述了php7 錯誤處理機(jī)制修改。分享給大家供大家參考,具體如下:

一、現(xiàn)在有兩個異常類:Exception and Error.

PHP7現(xiàn)在有兩個異常類,Exception and Error。這兩個類都實(shí)現(xiàn)了一個新的接口:Throwable。在您的異常處理代碼中,類型暗示可能需要調(diào)整下。

二、一些致命錯誤和可恢復(fù)致命錯誤改為拋出Error對象。

有一些致命錯誤和可恢復(fù)致命錯誤現(xiàn)在改為報(bào)出Error對象。Error對象是和Exception獨(dú)立的,它們無法被常規(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)造方法如果失敗的時候總會報(bào)出異常。之前的有一些構(gòu)造方法會返回NULL或者一個無法使用的對象。

五、一些E_STRICT錯誤的級別調(diào)整了。


PHP 7 錯誤處理

PHP 7 改變了大多數(shù)錯誤的報(bào)告方式。不同于 PHP 5 的傳統(tǒng)錯誤報(bào)告機(jī)制,現(xiàn)在大多數(shù)錯誤被作為 Error 異常拋出。

這種 Error 異??梢韵衿胀ó惓R粯颖?try / catch 塊所捕獲。如果沒有匹配的 try / catch 塊, 則調(diào)用異常處理函數(shù)(由 set_exception_handler() 注冊)進(jìn)行處理。 如果尚未注冊異常處理函數(shù),則按照傳統(tǒng)方式處理:被報(bào)告為一個致命錯誤(Fatal Error)。

Error 類并不是從 Exception 類 擴(kuò)展出來的,所以用 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

...

如何修改php7 錯誤處理機(jī)制修改

實(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é)果為:

Modulo by zero

PHP 7 異常

PHP 7 異常用于向下兼容及增強(qiáng)舊的assert()函數(shù)。它能在生產(chǎn)環(huán)境中實(shí)現(xiàn)零成本的斷言,并且提供拋出自定義異常及錯誤的能力。

老版本的API出于兼容目的將繼續(xù)被維護(hù),assert()現(xiàn)在是一個語言結(jié)構(gòu),它允許第一個參數(shù)是一個表達(dá)式,而不僅僅是一個待計(jì)算的 string或一個待測試的boolean。

assert() 配置

配置項(xiàng)默認(rèn)值可選值
zend.assertions1
  • 1 - 生成和執(zhí)行代碼 (開發(fā)模式)

  • 0 - 生成代碼,但在執(zhí)行時跳過它

  • -1 - 不生成代碼 (生產(chǎn)環(huán)境)

assert.exception0
  • 1 - 斷言失敗時拋出,可以拋出異常對象,如果沒有提供異常,則拋出 AssertionError 對象實(shí)例。

  • 0 - 使用或生成 Throwable, 僅僅是基于對象生成的警告而不是拋出對象(與 PHP 5 兼容)

參數(shù)

assertion

斷言。在 PHP 5 中,是一個用于執(zhí)行的字符串或者用于測試的布爾值。在 PHP 7 中,可以是一個返回任何值的表達(dá)式, 它將被執(zhí)行結(jié)果用于指明斷言是否成功。

description

如果 assertion 失敗了,選項(xiàng) description 將會包括在失敗信息里。

exception

在 PHP 7 中,第二個參數(shù)可以是一個       Throwable 對象,而不是一個字符串,如果斷言失敗且啟用了 assert.exception 該對象將被拋出。

實(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

感謝各位的閱讀,以上就是“如何修改php7 錯誤處理機(jī)制修改”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對如何修改php7 錯誤處理機(jī)制修改這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI