下面小編就為大家分享一篇基於PHP7錯誤處理與異常處理方法(詳解),具有很好的參考價值,希望對大家有幫助。一起跟著小編過來看看吧
PHP7錯誤處理
#PHP 7 改變了大多數錯誤的報告方式。不同於傳統(PHP 5)的錯誤報告機制,現在大多數錯誤被拋出作為 Error 異常。
這種 Error 異常可以像 Exception 異常一樣被第一個匹配的 try / catch 區塊所捕獲。如果沒有符合的 catch 區塊,則呼叫異常處理函數(事先透過 set_exception_handler() 註冊)進行處理。如果尚未註冊異常處理函數,則按照傳統方式處理:被報告為一個致命錯誤(Fatal Error)。
Error 類別並非繼承自 Exception 類,所以不能用 catch (Exception e)...來捕獲Error。你可以用catch(Errore) { … },或是透過註冊異常處理函數( set_exception_handler())來捕捉 Error。
Error 層次結構
#Throwable Error ArithmeticError pisionByZeroError AssertionError ParseError TypeError Exception ...
try { // Code that may throw an Exception or Error. } catch (Throwable $t) { // Executed only in PHP 7, will not match in PHP 5 } catch (Exception $e) { // Executed only in PHP 5, will not be reached in PHP 7 } up down 9 lubaev dot ka at gmail dot com ¶ 11 months ago php 7.1 try { // Code that may throw an Exception or ArithmeticError. } catch (ArithmeticError | Exception $e) { // pass }
#擴充功能(extend) PHP內建的例外處理類別
#使用者可以用自訂的例外處理類別來擴充PHP內建的例外處理類別。以下的程式碼說明了在內建的異常處理類別中,哪些屬性和方法在子類別中是可存取和繼承的。
Example #1 內建的例外處理類別#<?php class Exception { protected $message = 'Unknown exception'; // 异常信息 private $string; // __toString cache protected $code = 0; // 用户自定义异常代码 protected $file; // 发生异常的文件名 protected $line; // 发生异常的代码行号 private $trace; // backtrace private $previous; // previous exception if nested exception public function __construct($message = null, $code = 0, Exception $previous = null); final private function __clone(); // Inhibits cloning of exceptions. final public function getMessage(); // 返回异常信息 final public function getCode(); // 返回异常代码 final public function getFile(); // 返回发生异常的文件名 final public function getLine(); // 返回发生异常的代码行号 final public function getTrace(); // backtrace() 数组 final public function getPrevious(); // 之前的 exception final public function getTraceAsString(); // 已格成化成字符串的 getTrace() 信息 // Overrideable public function __toString(); // 可输出的字符串 } ?> 如果使用自定义的类来扩展内置异常处理类,并且要重新定义构造函数的话,建议同时调用 parent::__construct() 来检查所有的变量是否已被赋值。当对象要输出字符串的时候,可以重载 __toString() 并自定义输出的样式。 Note: Exception 对象不能被复制。尝试对 Exception 对象复制 会导致一个 E_ERROR 级别的错误。
<?php /** * 自定义一个异常处理类 */ class MyException extends Exception { // 重定义构造器使 message 变为必须被指定的属性 public function __construct($message, $code = 0, Exception $previous = null) { // 自定义的代码 // 确保所有变量都被正确赋值 parent::__construct($message, $code, $previous); } // 自定义字符串输出的样式 public function __toString() { return __CLASS__ . ": [{$this->code}]: {$this->message}\n"; } public function customFunction() { echo "A custom function for this type of exception\n"; } } /** * 创建一个用于测试异常处理机制的类 */ class TestException { public $var; const THROW_NONE = 0; const THROW_CUSTOM = 1; const THROW_DEFAULT = 2; function __construct($avalue = self::THROW_NONE) { switch ($avalue) { case self::THROW_CUSTOM: // 抛出自定义异常 throw new MyException('1 is an invalid parameter', 5); break; case self::THROW_DEFAULT: // 抛出默认的异常 throw new Exception('2 is not allowed as a parameter', 6); break; default: // 没有异常的情况下,创建一个对象 $this->var = $avalue; break; } } }
以上這篇基於PHP7錯誤處理與異常處理方法(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持php中文網。
您可能感興趣的文章:
PHP學習之預定義變數實例講解
######## #PHP 取得某年第幾週的開始日期和結束日期的實例講解################PHP介面多重繼承及tarits實現多重繼承效果的方法_php技巧### #########################以上是基於PHP7錯誤處理與異常處理方法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!