首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >命名参数生成的错误和函数调用中的参数解包装(而不是在PHP-8中抛出ErrorException )

命名参数生成的错误和函数调用中的参数解包装(而不是在PHP-8中抛出ErrorException )
EN

Stack Overflow用户
提问于 2020-10-20 03:34:41
回答 2查看 128关注 0票数 2

以下代码按预期工作:抛出ErrorException并为require生成的致命错误调用关机函数

代码语言:javascript
复制
register_shutdown_function(function() {
    echo "anyway, hello world\n";
});

set_error_handler(function($severity, $message, $file, $line) {
    throw new ErrorException($message, 0, $severity, $file, $line);
});

set_exception_handler(function($exception) {
    echo $exception->getMessage().PHP_EOL;
});

require "unavailable_file";

输出:

require(unavailable_file):未能打开流:没有这样的文件或目录

不管怎样,你好世界

但是,由命名参数生成的致命错误无法调用异常处理程序和关闭函数。

代码语言:javascript
复制
// replacing require in the previous code with the following

function foo() {}

foo(...[], bar: "baz");

输出:

致命错误:无法组合命名参数和参数解包装

合并所有这些也不像预期的那样工作,来自requirerequire也没有被捕获。

代码语言:javascript
复制
// ... 

require "unavailable_file";

function foo() {}

foo(...[], bar: "baz");

输出:

致命错误:无法组合命名参数和参数解包装

这是另一个窃听器还是我漏掉了什么?

PS: PHP版本为8.0.0RC2 (cli)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-10-21 12:55:52

正如评论中所指出的那样,确实存在着不同致命类型的致命错误。

因为这属于“执行脚本之前生成的”类别,因此很遗憾,关闭函数将永远不会被调用。糟糕的是,我没有找到任何显示哪些致命错误属于这一类别的信息。

票数 1
EN

Stack Overflow用户

发布于 2020-10-22 02:56:57

是的,原来这不是虫子!

E_COMPILE_ERROR型误差

致命编译时错误.这就像一个E_ERROR,只是它是由Zend脚本引擎生成的

还有E_PARSE

编译时分析错误。解析错误只应由解析器生成。

是这种行为的唯一原因(另外,如果进程是用SIGTERM,或SIGKILL信号或exitdie在关闭函数之前调用的话)

以下是此类错误的列表

  1. https://3v4l.org/oO4L7 function
  2. https://3v4l.org/cNHbu => private减除methods
  3. https://3v4l.org/jPpIU => Acess级别必须相同或限制较小的

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64438091

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档