Scope::dispose
(PHP 8.6+, True Async 1.0)
public function dispose(): void
Cancela de forma forzada todas las corrutinas del ámbito y lo cierra. Después de llamar a dispose(), el ámbito se marca como cerrado y cancelado. No se pueden agregar nuevas corrutinas a un ámbito cerrado.
Esto es equivalente a llamar a cancel() seguido del cierre del ámbito.
Valor de retorno
No se devuelve ningún valor.
Ejemplos
Ejemplo #1 Cierre forzado de un ámbito
<?php
use Async\Scope;
$scope = new Scope();
$scope->spawn(function() {
try {
\Async\delay(60_000);
} catch (\Async\CancelledException) {
echo "Coroutine cancelled on dispose\n";
}
});
// All coroutines will be cancelled, scope closed
$scope->dispose();
var_dump($scope->isClosed()); // bool(true)
var_dump($scope->isCancelled()); // bool(true)
Ejemplo #2 Limpieza en un bloque try/finally
<?php
use Async\Scope;
$scope = new Scope();
try {
$scope->spawn(function() {
// Business logic
\Async\delay(5000);
});
$scope->awaitCompletion();
} finally {
$scope->dispose();
}
Ver también
- Scope::disposeSafely — Cierre seguro (con zombis)
- Scope::disposeAfterTimeout — Cerrar después de un tiempo límite
- Scope::cancel — Cancelar sin cerrar el ámbito