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

booltrue 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