前言
第一部分: 半协程调度器
- 统一生成器接口
- 生成器迭代
- 生成器返回值
- 生成器委托
- 改写 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: 请求超时
- 一个综合示例
附录
参考
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
spawn
spawn
为了易用性,我们为AsyncTask
的创建一个可灵活传递参数函数入口。
<?php
/**
* spawn one semicoroutine
*
* @internal param callable|\Generator|mixed $task
* @internal param callable $continuation function($r = null, $ex = null) {}
* @internal param AsyncTask $parent
* @internal param array $ctx Context也可以附加在 \Generator 对象的属性上
*
* 第一个参数为task
* 剩余参数(优先检查callable)
* 如果参数类型 callable 则参数被设置为 Continuation
* 如果参数类型 AsyncTask 则参数被设置为 ParentTask
* 如果参数类型 array 则参数被设置为 Context
*/
function spawn()
{
$n = func_num_args();
if ($n === 0) {
return;
}
$task = func_get_arg(0);
$continuation = function() {};
$parent = null;
$ctx = [];
for ($i = 1; $i < $n; $i++) {
$arg = func_get_arg($i);
if (is_callable($arg)) {
$continuation = $arg;
} else if ($arg instanceof AsyncTask) {
$parent = $arg;
} else if (is_array($arg)) {
$ctx = $arg;
}
}
if (is_callable($task)) {
try {
$task = $task();
} catch (\Exception $ex) {
$continuation(null, $ex);
return;
}
}
if ($task instanceof \Generator) {
foreach ($ctx as $k => $v) {
$task->$k = $v;
}
(new AsyncTask($task, $parent))->begin($continuation);
} else {
$continuation($task, null);
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

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