基于PHP7错误处理与异常处理方法(详解)

时间:2022-08-28 16:18:54
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 层次结构
  1. Throwable 
  2. Error 
  3.   ArithmeticError 
  4.    DivisionByZeroError 
  5.   AssertionError 
  6.   ParseError 
  7.   TypeError 
  8. Exception 
  9.   ... 


 

  1. try 
  2. // Code that may throw an Exception or Error. 
  3. catch (Throwable $t) 
  4. // Executed only in PHP 7, will not match in PHP 5 
  5. catch (Exception $e) 
  6. // Executed only in PHP 5, will not be reached in PHP 7 
  7. up 
  8. down 
  9. lubaev dot ka at gmail dot com ¶ 
  10. 11 months ago 
  11. php 7.1 
  12. try { 
  13. // Code that may throw an Exception or ArithmeticError. 
  14. catch (ArithmeticError | Exception $e) { 
  15. // pass 



扩展(extend) PHP内置的异常处理类

用户可以用自定义的异常处理类来扩展PHP内置的异常处理类。以下的代码说明了在内置的异常处理类中,哪些属性和方法在子类中是可访问和继承的。

Example #1 内置的异常处理类

  1. <?php 
  2. class Exception 
  3. protected $message = 'Unknown exception'// 异常信息 
  4. private $string;       // __toString cache 
  5. protected $code = 0;      // 用户自定义异常代码 
  6. protected $file;       // 发生异常的文件名 
  7. protected $line;       // 发生异常的代码行号 
  8. private $trace;       // backtrace 
  9. private $previous;      // previous exception if nested exception 
  10. public function __construct($message = null, $code = 0, Exception $previous = null); 
  11. final private function __clone();   // Inhibits cloning of exceptions. 
  12. final public function getMessage();  // 返回异常信息 
  13. final public function getCode();   // 返回异常代码 
  14. final public function getFile();   // 返回发生异常的文件名 
  15. final public function getLine();   // 返回发生异常的代码行号 
  16. final public function getTrace();   // backtrace() 数组 
  17. final public function getPrevious();  // 之前的 exception 
  18. final public function getTraceAsString(); // 已格成化成字符串的 getTrace() 信息 
  19. // Overrideable 
  20. public function __toString();    // 可输出的字符串 
  21. ?> 


如果使用自定义的类来扩展内置异常处理类,并且要重新定义构造函数的话,建议同时调用 parent::__construct() 来检查所有的变量是否已被赋值。当对象要输出字符串的时候,可以重载 __toString() 并自定义输出的样式。
Note:
Exception 对象不能被复制。尝试对 Exception 对象复制 会导致一个 E_ERROR 级别的错误。
  1. <?php 
  2. /** 
  3. * 自定义一个异常处理类 
  4. */ 
  5. class MyException extends Exception 
  6. // 重定义构造器使 message 变为必须被指定的属性 
  7. public function __construct($message, $code = 0, Exception $previous = null) { 
  8.   // 自定义的代码 
  9.   // 确保所有变量都被正确赋值 
  10.   parent::__construct($message, $code, $previous); 
  11. // 自定义字符串输出的样式 
  12. public function __toString() { 
  13.   return __CLASS__ . ": [{$this->code}]: {$this->message}\n"
  14. public function customFunction() { 
  15.   echo "A custom function for this type of exception\n"
  16.  
  17. /** 
  18. * 创建一个用于测试异常处理机制的类 
  19. */ 
  20. class TestException 
  21. public $var
  22. const THROW_NONE = 0; 
  23. const THROW_CUSTOM = 1; 
  24. const THROW_DEFAULT = 2; 
  25. function __construct($avalue = self::THROW_NONE) { 
  26.   switch ($avalue) { 
  27.    case self::THROW_CUSTOM: 
  28.     // 抛出自定义异常 
  29.     throw new MyException('1 is an invalid parameter', 5); 
  30.     break
  31.    case self::THROW_DEFAULT: 
  32.     // 抛出默认的异常 
  33.     throw new Exception('2 is not allowed as a parameter', 6); 
  34.     break
  35.    default
  36.     // 没有异常的情况下,创建一个对象 
  37.     $this->var = $avalue; 
  38.     break
  39.   } 


以上这篇基于PHP7错误处理与异常处理方法(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。