当前位置:首页 > PHP > 正文内容

php event异常处理,php set_exception_handler无效

高老师6年前 (2020-03-29)PHP2156

(1).今天遇到一件奇怪的事情,在event事件中是无法自定义异常处理,例如我们使用set_exception_handler来统一处理异常。例如下面的代码:

<?php
error_reporting(E_ALL);
set_error_handler(function ($errno, $errStr, $errFile, $errLine){
    var_dump($errno, $errStr, $errFile, $errLine);
});
set_exception_handler(function ($exception){
    var_dump($exception->getMessage());
});


function aa()
{
    a();
}


//创建event配置.[空配置]
$eventConfig = new EventConfig(); 

//创建eventBase对象.event的所有基础类
$eventBase = new EventBase($eventConfig);

//创建event事件
$event = new Event($eventBase,-1,Event::TIMEOUT | Event::PERSIST,function(){
    echo 'date:'.date('Y-m-d H:i:s').PHP_EOL;
    aa();
});

//将创建的event事件扔到eventBase中,并设置超时时间为0.5秒
$event->add(2);

//让eventBase对象开始进入事件循环
$eventBase->loop();

我本来以为掉用不存在的a方法应该会触发set_exception_handler方法捕捉到。事实上上面的代码运行后不会报错,并且输出一次日期后就阻塞了。

(2).实际上event和swoole是一样的,运行以后会接管系统控制权,在其内部已经存在一个大的try catch,已经将异常捕获到了,捕获到异常的event还不打算退出进程,并且event扩展不继续把异常向上抛,这就导致了程序依然在阻塞,但是并不执行。我们来验证这件事情。例如我们是无法捕获整个event异常的

<?php
function aa()
{
    a();
}

try
{
    //创建event配置.[空配置]
    $eventConfig = new EventConfig();

    //创建eventBase对象.event的所有基础类
    $eventBase = new EventBase($eventConfig);

    //创建event事件
    $event = new Event($eventBase,-1,Event::TIMEOUT | Event::PERSIST,function(){
        echo 'date:'.date('Y-m-d H:i:s').PHP_EOL;
        aa();
    });

    //将创建的event事件扔到eventBase中,并设置超时时间为0.5秒
    $event->add(2);

    //让eventBase对象开始进入事件循环
    $eventBase->loop();
}
catch (Throwable $exception)
{
    var_dump($exception->getMessage());
}

(3).既然对event整体没有办法捕捉异常,那我们可以对其执行的代码做异常啊,毕竟是先实例化的event,例如下面的代码成功捕获异常

<?php
function aa()
{
    a();
}

//创建event配置.[空配置]
$eventConfig = new EventConfig();

//创建eventBase对象.event的所有基础类
$eventBase = new EventBase($eventConfig);

//创建event事件
$event = new Event($eventBase, -1, Event::TIMEOUT | Event::PERSIST, function () {
    echo 'date:' . date('Y-m-d H:i:s') . PHP_EOL;
    try
    {
        aa();
    }
    catch (Throwable $exception)
    {
        var_dump($exception->getMessage());
    }
});

//将创建的event事件扔到eventBase中,并设置超时时间为0.5秒
$event->add(2);

//让eventBase对象开始进入事件循环
$eventBase->loop();

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/129.html

分享给朋友:

“php event异常处理,php set_exception_handler无效” 的相关文章

php 开启错误提示,php 关闭错误提示

php 开启错误提示,php 关闭错误提示

开启错误提示代码:ini_set("display_errors", "On"); error_reporting(E_ALL | E_STRICT);关闭错误提示代码:error_reporting(E_ALL ^&n...

php数组合并 array_merge和+号的区别

php数组合并 array_merge和+号的区别

array_merge是最常用的数组合并方法,+号同样也可以,但是却有很大不同。array_merge遇到相同字符串key,后面数组的key会覆盖前面数组的key,+号正好相反。$a = [ 'one' => 'A on...

php arrayaccess的应用场景:配置管理器

php arrayaccess的应用场景:配置管理器

上篇文章已经讲解arrayacces的原理,现在来讲解下arrayaccess的实际应用。一个大型的互联网项目中必然会存在各种配置信息,例如多种数据库信息:mysql,tidb,mongodb,redis,某个业务模块单独的配置信息如比例,额度等等,那么该如何治理配置信息?PHP项目中大部分的框架都...

PHP getenv函数和putenv函数的学习

PHP getenv函数和putenv函数的学习

(1).在PHP中可以查看的环境变量包括: (1.1).电脑环境变量 (2.1).服务器环境变量(2).getenv()函数获取一个环境变量的值.参数1是环境变量的key,参数2值为true的时候仅从你的电脑环境变量中查找,参数2值为false会从两种变量中全部查询//获取我电脑登录的用户名,输出A...

PHP Warning:  ftok(): Project identifier is invalid

PHP Warning: ftok(): Project identifier is invalid

在使用ftok生成ipc进程通信key尝试将第二个参数项目标识符传入字符串报错:PHP Warning:  ftok(): Project identifier is invalid,查阅资料发现第二个字符串只能是1个字符串,长度为1....

php下载远程文件(支持断点续传,支持超大文件)

php下载远程文件(支持断点续传,支持超大文件)

断点下载的原理:http请求头添加Range参数告诉文件服务器端需要的字节范围例如1个文本文件的字节为1000,第一次请求Range: bytes=0-500第二次请求Range: bytes=501-1000通过每次的请求将返回的流追加写入到文件。注意的项目:断点下载服务器端的每次只返回字节传输的...