swoole使用協程順序執行任務,就需要依賴Channel了。
Channel特點
與容量有關
如果channel未滿,push不阻塞,如果已滿,push讓出控制流;
如果channel爲空,pop讓出控制流。
具體例子:
<?php
use \Swoole\Coroutine\Channel;
$chan = new Channel(50);
function provider01(Channel $chan) {
//睡眠時間可加可不加,單位秒
Co::sleep(1);
//一些業務邏輯
$chan->push(['status' => '生產者完成消息01']);
}
function provider02(Channel $chan) {
//睡眠時間可加可不加,單位秒
Co::sleep(1);
//一些業務邏輯
$chan->push(['status' => '生產者完成消息02']);
}
//順序執行任務
go("provider01", $chan);
go("provider02", $chan);
go(function() use($chan) {
// chan元素個數
$chanNum = 2;
// chan有數據時
while($chanNum>0) {
$item = $chan->pop();
if($item){
var_dump($item);
$chanNum --;
}
}
});