Coroutine\Channel::select

废弃

此方法存在安全问题,已废弃

通道读写检测。类似于socket_selectstream_select可以检测channel是否可进行读写。

原型

function Coroutine\Channel::select(array &$read, array &$write, float $timeout = 0);

$read$write数组中有部分channel对象处于可读或可写状态,select会立即返回,不会产生协程调度。当数组中没有任何channel可读或可写时,将挂起当前协程,并设置定时器。当其中一个通道可读或可写时,将重新唤醒当前协程。

select操作只检测channel列表的可读或可写状态,但并不会读写channel,在select调用返回后,可遍历$read$write数组,执行poppush方法,完成通道读写操作。

参数

返回值

注意事项

早期版本中Coroutine\Channel由于存在一些问题,在Swoole4.0.3版本重构并废弃了 Coroutine\Channel::select 方法。所以在Swoole4.0.3以上的版本请使用channel->pop($timeout)替代。

fibonacci 实例

$c1 = new chan();
$c2 = new chan();
function fibonacci($c1, $c2)
{
    go(function () use ($c1, $c2) {
        $a = 0;
        $b = 1;
        while(1) {
            $read_list = [$c2];
            $write_list = [$c1];
            $result = chan::select($read_list, $write_list, 2);
            if ($write_list) {
                $t = $a + $b;
                $a = $b;
                $b = $t;
                $c1->push($a);
            }
            if ($read_list) {
                $ret = $c2->pop();
                if ($ret === 1) {
                    return 1;
                }
            }
        }
    });
}
$num = 10;
go(function () use ($c1, $c2, $num) {
    for ($i = 0; $i < $num; $i ++) {
        $ret = $c1->pop();
        echo "fibonacci @$i $ret\n";
    }
    $c2->push(1);
});    
fibonacci($c1, $c2);