• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

PHP 7 错误异常级别

php 搞代码 4年前 (2022-01-22) 19次浏览 已收录 0个评论

这篇文章介绍的内容是关于PHP7错误异常级别,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

PHP 7 错误异常级别

探究 PHP 7 的异常层次结构

在过去的 PHP 中,几乎不可能会去处理致命错误。致命错误只会轻易的终止脚本执行,而不会调用 set_error_hander() 错误处理程序。

在 PHP 7 中,当致命或是可恢复性错误 (E_ERROR and E_RECOVERABLE_ERROR) 发生时,异常会被捕获,而不是中止脚本。在特定的情况下,还是存在会致命的错误,比如内存不足之类,也会像之前一样立即中止脚本。PHP 7 中未捕获的异常依旧时致命错误。这意味着,如果 PHP 5.x 中未捕获的异常,在 PHP 7 中依旧是致命错误。

注意,例如警告或是通知错误在 PHP 7 中保持8本文来源gao.dai.ma.com搞@代*码(网$

搞代gaodaima码

不变,只有致命错误或是可恢复性错误会抛出异常。

致命或是可恢复性错误的抛出并不延伸自 Exception 类。这种分离是为了防止现存的 PHP 5.x 代码接收到的错误异常调用到终止程序。致命或是可恢复错误抛出的异常将实例化一个新的异常类:Error。和其他异常类相同,被捕获到的 Error 类将会在最后一个程序块执行完毕之后再行处理。

相较于 PHP 7 alpha-2 之前,PHP 7 的异常类层次有所不同, 被抛出的致命和可恢复性的错误将于 EngineException 类实例化,而 EnginException 类并不继承于 Exception。Exception 和 EngineException 都继承于 BaseException。

Throwable

为了联合这两个异常分支,Exception 和 Error 都实现了一个新的接口,Throwable。

PHP 7 中新的异常层次如下:

Throwable //(接口)    |- Exception implements Throwable        |- ...    |- Error implements Throwable        |- TypeError extends Error         |- ParseError extends Error // 编译时错误        |- ArithmeticError extends Error            |- pisionByZeroError extends ArithmeticError        |- AssertionError extends Error

如果在 PHP 7 中定义 Throwable 接口,那应该和下面的代码相近。

interface Throwable{    public function getMessage(): string;    public function getCode(): int;    public function getFile(): string;    public function getLine(): int;    public function getTrace(): array;    public function getTraceAsString(): string;    public function getPrevious(): Throwable;    public function __toString(): string;}

这个接口应当很熟悉。Throwable 特定的方法和 Exception 的相同。唯一不同的是 Throwable::getPrevious() 会返回 Throwable Exception 和 Error 类的构造函数都将接收一个 Throwable 的实例作为先前的异常。

Throwable 可以在 try/catch 块中用老捕获异常或是错误对象(将来可能可以捕获更多的异常类型)。记住,这里更建议捕获更为具体的异常类,并采取相应的处理措施。然而,在一些场合下,需要宽泛的捕获异常(比如日志或是框架的错误处理)。在 PHP 7 中,这些异常捕获块更适合使用 Throwable 而不是 Exception。

try {    // Code that may throw an Exception or Error.} catch (Throwable $t) {    // Handle exception}

自定义类不能实现 Throwable 插件,这个部分由于可预见性和一致性:只有实例化 Excetion 和 Error 类才能抛出异常。此外,异常携带了栈中被创建的对象的信息。自定义类并未自动拥有保存信息的参数。

Throwable can be extended to create package-specific interfaces or add additional methods. 只有继承了 Exception 或是 Error 的类才可以实现拓展了 Throwable 的插件。

interface MyPackageThrowable extends Throwable {}class MyPackageException extends Exception implements MyPackageThrowable {}throw new MyPackageException();

Error

在 PHP 5.下版本中所有的 errors 都是致命错误或是可恢复性致命错误,而在 PHP 7 中都抛出 Error 的实例化。像其他异常 Error 对象可以通过 try/catch 程序块捕获。

$var = 1;try {    $var->method(); // Throws an Error object in PHP 7.} catch (Error $e) {    // Handle error}

通常,之前的致命错误都将抛出 Error 基类的实例化,但是一些错误会抛出更加确切的 Error 子类:TypeError, ParseError, and AssertionError。

TypeError (类型错误)

TypeError 实例化的抛出是由实参和形参 当调用函数时申明的形参和实参类型不一致(传入参数和方法中定义的参数类型不一致)将会抛出一个 TypeError 实例。

function add(int $left, int $right){    return $left + $right;}try {    $value = add('left', 'right');} catch (TypeError $e) {    echo $e->getMessage(), "\n";}

得到的输出:

Argument 1 passed to add() must be of the type integer, string given

ParseError (解析错误)

included/required 文件,或者 eval() 中的代码包含语法错误时,ParseError 将会被抛出。

try {    require 'file-with-parse-error.php';} catch (ParseError $e) {    echo $e->getMessage(), "\n";}

ArithmeticError (算数错误)

抛出 ArithmeticError 错误有两种情况:负数位移,或者使用 PHP_INT_MIN 当作分子,-1 做分母调用 intp()(PHP_INI_MIN / -1 返回值是浮点型)。

try {    $value = 1 << -1;} catch (ArithmeticError $e) {    echo $e->getMessage(), "\n";}

pisionByZeroError (分母为零)

分母为零时使用 intp() 或者取余(%) 会抛出 pisionByZeroError 错误。注意,除零只会引起一个警告,计算结果为 NaN。

try {    $value = 1 % 0;} catch (pisionByZeroError $e) {    echo $e->getMessage(), "\n";}

AssertionError (断言)

当不满足 assert() 设定的条件时,将会抛出一个 AssertionError 错误。

ini_set('zend.assertions', 1);ini_set('assert.exception', 1);$test = 1;assert($test === 0);

不满足 assert() 设定的条件,抛出一个 AssertionError 错误,并且 assert.exception = 1,异常输出如下:

Fatal error: Uncaught AssertionError: assert($test === 0)

assert() is only executed and will only throw an AssertionError if assertions are enabled and set to throw exceptions with ini settings zend.assertions = 1 and assert.exception = 1.

使用 Error

用户可以创建自己的 Error 类,作为 Error 基类的拓展。这可能带来重要的问题:什么场合下应该抛出一个 Exception 类的子类实例,什么场合下又应该抛出 Error 类的子类实例?

由于错误对象不应当在程序运行中处理,捕获错误对象应当是少见的。通常而言,错误对象应当捕获并记录之,执行必要的清理,并给用户展示错误信息。

编写兼容 PHP 5.x 和 7 Exceptions 类的代码

在 PHP 5.x 和 7 使用相同的代码捕获异常,可以实用多重捕获代码块,首先捕获 Throwable,之后时 Exception。一旦不需要维护 PHP 5.x 的系统,代码块可以立刻被清理掉。

try {    // Code that may throw an Exception or Error.} catch (Throwable $t) {    // Executed only in PHP 7, will not match in PHP 5.x} catch (Exception $e) {    // Executed only in PHP 5.x, will not be reached in PHP 7}

英文原文: trowski.com/2015

本文虽拙,却也系作者劳动,转载还请保留本文链接: http://cyleft.com/?p=721

相关推荐:

php错误级别详解

PHP错误与异常调试视频教程资源分享

以上就是PHP 7 错误异常级别的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:PHP 7 错误异常级别

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址