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
bool – true 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
- Coroutine::getResult – Obtener el resultado
- Coroutine::getException – Obtener la excepción
- Coroutine::isCancelled – Verificar cancelación