swoole協程(Coroutine\Channel)

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 --;
        }
    }
});

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章