Scope::dispose

(PHP 8.6+, True Async 1.0)

public function dispose(): void

Cancella forzatamente tutte le coroutine nello scope e lo chiude. Dopo aver chiamato dispose(), lo scope viene contrassegnato sia come chiuso che come cancellato. Non e’ possibile aggiungere nuove coroutine a uno scope chiuso.

Questo equivale a chiamare cancel() seguito dalla chiusura dello scope.

Valore di ritorno

Non viene restituito alcun valore.

Esempi

Esempio #1 Chiusura forzata di uno scope

<?php

use Async\Scope;

$scope = new Scope();

$scope->spawn(function() {
    try {
        \Async\delay(60_000);
    } catch (\Async\CancelledException) {
        echo "Coroutine cancellata al dispose\n";
    }
});

// Tutte le coroutine saranno cancellate, scope chiuso
$scope->dispose();

var_dump($scope->isClosed());    // bool(true)
var_dump($scope->isCancelled()); // bool(true)

Esempio #2 Pulizia in un blocco try/finally

<?php

use Async\Scope;

$scope = new Scope();

try {
    $scope->spawn(function() {
        // Logica di business
        \Async\delay(5000);
    });

    $scope->awaitCompletion();
} finally {
    $scope->dispose();
}

Vedi anche