前言
第一部分: 半协程调度器
- 统一生成器接口
- 生成器迭代
- 生成器返回值
- 生成器委托
- 改写 return
- 抽象异步模型
- 引入异常处理
- 异常: 嵌套任务透传
- 异常: 传递流程
- 异常: 重新进行 CPS 变换
- 异常: 重新加入 Async
- Syscall 与 Context
- 调度器: 里程碑
- spawn
- callcc
- race 与 timeout
- all 与 parallel
- channel 与协程间通信
- 无缓存 channel
- 缓存 channel
- channel 演示
- FutureTask 与 fork
第二部分: Koa
- 穿越地心之旅
- 洋葱圈模型
- rightReduce与中间件compose
- Koa::Application
- Koa::Context
- Koa::Request
- Koa::Response
- Koa - HelloWorld
- Middleware Interface
- Middleware: 全局异常处理
- Middleware: Router
- Middleware: 请求超时
- 一个综合示例
附录
参考
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
引入异常处理
引入异常处理
尽管只有寥寥几行代码,我们却已经实现了可工作的半协程调度器(缺失异常处理)。
没关系,下面先rollback回return的实现,开始引入异常处理,目标是在嵌套生成器之间正确向上抛出异常,跨生成器捕获异常。
<?php
// 为Gen引入throw方法
class Gen
{
// PHP7 之前 关键词不能用作名字
public function throw_(\Exception $ex)
{
return $this->generator->throw($ex);
}
}
final class AsyncTask
{
public function begin()
{
return $this->next();
}
// 这里添加第二个参数, 用来在迭代过程传递异常
public function next($result = null, \Exception $ex = null)
{
if ($ex) {
$this->gen->throw_($ex);
}
$ex = null;
try {
// send方法内部是一个resume的过程:
// 恢复execute_data上下文, 调用zend_execute_ex()继续执行,
// 后续中op_array内可能会抛出异常
$value = $this->gen->send($result);
} catch (\Exception $ex) {}
if ($ex) {
if ($this->gen->valid()) {
// 传递异常
return $this->next(null, $ex);
} else {
throw $ex;
}
} else {
if ($this->gen->valid()) {
// 正常yield值
return $this->next($value);
} else {
return $result;
}
}
}
}
<?php
function newGen()
{
$r1 = (yield 1);
throw new \Exception("e");
$r2 = (yield 2);
yield 3;
}
$task = new AsyncTask(newGen());
try {
$r = $task->begin();
echo $r;
} catch (\Exception $ex) {
echo $ex->getMessage(); // output: e
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论