Coroutine::isCompleted
(PHP 8.6+, True Async 1.0)
public Coroutine::isCompleted(): bool
Vérifie si la coroutine a fini son exécution. Une coroutine est considérée comme terminée en cas de terminaison réussie, de terminaison avec erreur ou d’annulation.
Valeur de retour
bool – true si la coroutine a fini son exécution.
Exemples
Exemple #1 Vérification de la terminaison
<?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)
Exemple #2 Vérification non bloquante de la disponibilité
<?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')),
];
// Attendre que toutes soient terminées
while (true) {
$allDone = true;
foreach ($tasks as $task) {
if (!$task->isCompleted()) {
$allDone = false;
break;
}
}
if ($allDone) break;
suspend();
}
Voir aussi
- Coroutine::getResult – Obtenir le résultat
- Coroutine::getException – Obtenir l’exception
- Coroutine::isCancelled – Vérifier l’annulation