(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();
<?php //对比$this和self /* * $this更倾向于对象本身 * */ class Par{ public  ...
在一个正式项目中操作人员提交239个产品信息进行保存,但是系统却提示没有提交239个产品,于是开启错误信息,显示如下:Warning: Unknown: Input variables exceeded 1000. To incr...
逛公众号文章看到文章"php实现事件监听与触发的方法,你用过吗?",我就好奇了,php又不是asp.net的webform,哪里来的服务端事件监听。于是学习了一波。先看下监听类:class Event { /** &nbs...
<?php $member = new class { public function getInfo() { ...
【一】.迭代器迭代是指反复执行一个过程,每执行一次叫做一次迭代。比如下面的代码就叫做迭代:1. <?php 2. $data = ['1', '2', &...
php7.1引入了PHP异步信号处理函数pcntl_async_signals() 来处理阻塞问题。在php7之前信号处理方式有2种,第一种是基于ticks来每执行一行代码来触发执行信号监听,第二种是直接while(true){ //监听信号 }第一种方式如果某行的代码阻塞时间较长会影响...