swoole_server->taskWaitMulti [编辑本页]

并发执行多个Task

array swoole_server->taskWaitMulti(array $tasks, double $timeout);
  • $tasks 必须为数字索引数组,不支持关联索引数组,底层会遍历$tasks将任务逐个投递到Task进程
  • $timeout 为浮点型,单位为秒
  • 执行成功返回一个结果数据,数组的key与传入的$tasks一致
  • 某个任务执行超时不会影响其他任务,返回的结果数据中将不包含超时的任务

使用实例

$tasks[] = mt_rand(1000, 9999); //任务1
$tasks[] = mt_rand(1000, 9999); //任务2
$tasks[] = mt_rand(1000, 9999); //任务3
var_dump($tasks);

//等待所有Task结果返回,超时为10s
$results = $serv->taskWaitMulti($tasks, 10.0);

if (!isset($results[0])) {
    echo "任务1执行超时了\n";
}
if (isset($results[1])) {
    echo "任务2的执行结果为{$results[1]}\n";
}
if (isset($results[2])) {
    echo "任务3的执行结果为{$results[2]}\n";
}

taskWaitMulti接口在1.8.8或更高版本可用