Coroutine::isCompleted

(PHP 8.6+, True Async 1.0)

public Coroutine::isCompleted(): bool

Verifica si la coroutine ha terminado su ejecución. Una coroutine se considera completada tras una finalización exitosa, una finalización con error, o una cancelación.

Valor de retorno

booltrue si la coroutine ha terminado su ejecución.

Ejemplos

Ejemplo #1 Verificar finalización

<?php

use function Async\spawn;
use function Async\await;

$coroutine = spawn(function() {
    return "test";
});

var_dump($coroutine->isCompleted()); // bool(false)

await($coroutine);

var_dump($coroutine->isCompleted()); // bool(true)

Ejemplo #2 Verificación de disponibilidad sin bloqueo

<?php

use function Async\spawn;
use function Async\suspend;

$tasks = [
    spawn(fn() => file_get_contents('https://api1.example.com')),
    spawn(fn() => file_get_contents('https://api2.example.com')),
];

// Esperar hasta que todas hayan completado
while (true) {
    $allDone = true;
    foreach ($tasks as $task) {
        if (!$task->isCompleted()) {
            $allDone = false;
            break;
        }
    }
    if ($allDone) break;
    suspend();
}

Ver también