在 Swoole4
中可以使用 Channel 实现协程间的通信、依赖管理、协程同步。基于 Channel 可以很容易地实现 Golang
的 sync.WaitGroup
功能。
此功能是使用 PHP 编写的功能,并不是 C/C++ 代码,实现源代码在 Library 当中
add
方法增加计数
done
表示任务已完成
wait
等待所有任务完成恢复当前协程的执行
WaitGroup
对象可以复用,add
、done
、wait
之后可以再次使用
<?php use Swoole\Coroutine; use Swoole\Coroutine\WaitGroup; use Swoole\Coroutine\Http\Client; use function Swoole\Coroutine\run; run(function () { $wg = new WaitGroup(); $result = []; $wg->add(); //启动第一个协程 Coroutine::create(function () use ($wg, &$result) { //启动一个协程客户端client,请求淘宝首页 $cli = new Client('www.taobao.com', 443, true); $cli->setHeaders([ 'Host' => 'www.taobao.com', 'User-Agent' => 'Chrome/49.0.2587.3', 'Accept' => 'text/html,application/xhtml+xml,application/xml', 'Accept-Encoding' => 'gzip', ]); $cli->set(['timeout' => 1]); $cli->get('/index.php'); $result['taobao'] = $cli->body; $cli->close(); $wg->done(); }); $wg->add(); //启动第二个协程 Coroutine::create(function () use ($wg, &$result) { //启动一个协程客户端client,请求百度首页 $cli = new Client('www.baidu.com', 443, true); $cli->setHeaders([ 'Host' => 'www.baidu.com', 'User-Agent' => 'Chrome/49.0.2587.3', 'Accept' => 'text/html,application/xhtml+xml,application/xml', 'Accept-Encoding' => 'gzip', ]); $cli->set(['timeout' => 1]); $cli->get('/index.php'); $result['baidu'] = $cli->body; $cli->close(); $wg->done(); }); //挂起当前协程,等待所有任务完成后恢复 $wg->wait(); //这里 $result 包含了 2 个任务执行结果 var_dump($result); });