TaskGroup::any

(PHP 8.6+, True Async 1.0)

public TaskGroup::any(): Async\Future

Devuelve un Future que se resuelve con el resultado de la primera tarea completada exitosamente. Las tareas que fallaron con un error se omiten. Las tareas restantes continúan ejecutándose.

Si todas las tareas fallan con errores, el Future se rechaza con CompositeException.

El Future devuelto soporta un token de cancelación mediante await(?Completable $cancellation).

Valor de retorno

Async\Future — un resultado futuro de la primera tarea exitosa. Llame a ->await() para obtener el valor.

Errores

Ejemplos

Ejemplo #1 Primera exitosa

<?php

use Async\TaskGroup;

spawn(function() {
    $group = new TaskGroup();

    $group->spawn(fn() => throw new \RuntimeException("fallo 1"));
    $group->spawn(fn() => throw new \RuntimeException("fallo 2"));
    $group->spawn(fn() => "éxito!");

    $result = $group->any()->await();
    echo $result . "\n"; // "éxito!"

    // Los errores de las tareas fallidas deben suprimirse explícitamente
    $group->suppressErrors();
});

Ejemplo #2 Todas fallaron

<?php

use Async\TaskGroup;

spawn(function() {
    $group = new TaskGroup();

    $group->spawn(fn() => throw new \RuntimeException("err 1"));
    $group->spawn(fn() => throw new \RuntimeException("err 2"));

    $group->seal();

    try {
        $group->any()->await();
    } catch (\Async\CompositeException $e) {
        echo count($e->getExceptions()) . " errores\n"; // "2 errores"
    }
});

Ejemplo #3 Búsqueda resiliente con tiempo de espera

<?php

use Async\TaskGroup;

spawn(function() {
    $group = new TaskGroup();

    $group->spawn(fn() => searchGoogle($query));
    $group->spawn(fn() => searchBing($query));
    $group->spawn(fn() => searchDuckDuckGo($query));

    $timeout = Async\timeout(3.0);

    try {
        $result = $group->any()->await($timeout);
    } catch (Async\TimeoutException) {
        echo "Ningún proveedor respondió en 3 segundos\n";
    }

    $group->suppressErrors();
});

Ver también