php7 try catch throw,基于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

DivisionByZeroError

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 内置的异常处理类

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 级别的错误。

/**

* 自定义一个异常处理类

*/

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错误处理与异常处理方法(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持聚米学院。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值