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
- Scope::disposeSafely — Chiusura sicura (con zombie)
- Scope::disposeAfterTimeout — Chiusura dopo un timeout
- Scope::cancel — Cancella senza chiudere lo scope