Coroutine::create
最后更新于:2022-04-02 06:25:42
# Coroutine::create
[TOC]
创建一个新的协程,并立即执行。
~~~
function Swoole\Coroutine::create(callable $function, ...$args) : int|false;
function go(callable $function, ...$args) : int|false; // 短名API
~~~
## 参数
* `$function`协程执行的代码,必须为`callable`,系统能创建的协程总数量受限于`server->max_coroutine`设置
## 返回值
* 创建失败返回`false`
* 创建成功返回协程的`ID`
由于底层会优先执行子协程的代码,因此只有子协程挂起时,`Coroutine::create`才会返回,继续执行当前协程的代码。
在`2.1.0`或更高版本中如果开启了`swoole.use_shortname`,可以直接使用`go`关键词创建新的协程。
~~~
go(function () {
$db = new Co\MySQL();
$server = array(
'host' => '127.0.0.1',
'user' => 'root',
'password' => 'root',
'database' => 'test',
);
$db->connect($server);
$result = $db->query('SELECT * FROM userinfo WHERE id = 3');
var_dump($result);
});
~~~
## 执行顺序
在一个协程中使用`go`嵌套创建新的协程。因为`Swoole`的协程是单线程模型,因此:
* 使用`go`创建的子协程会优先执行,子协程执行完毕或挂起时,将重新回到父协程向下执行代码
* 如果子协程挂起后,父协程退出,不影响子协程的执行
~~~
go(function() {
go(function () {
co::sleep(3.0);
go(function () {
co::sleep(2.0);
echo "co[3] end\n";
});
echo "co[2] end\n";
});
co::sleep(1.0);
echo "co[1] end\n";
});
~~~
## 协程开销
协程需要创建单独的内存栈,在`PHP-7.2`版本中底层会分配`8K`的`stack`来存储协程的变量,`zval`的尺寸为`16`字节,因此`8K`的`stack`最大可以保存`512`个变量。协程栈内存占用超过`8K`后`ZendVM`会自动扩容。
协程退出时会释放申请的`stack`内存。
> `PHP-7.1`、`PHP-7.0`默认会分配`256K`栈内存
> 可调用`Co::set(['stack_size' => 4096])`修改默认的栈内存尺寸
';