Future::failed
(PHP 8.6+, True Async 1.0)
public static function failed(\Throwable $throwable): Future
Створює Future, який негайно завершується із зазначеною помилкою. Виклик await() на такому Future викине переданий виняток.
Параметри
throwable — виняток, з яким Future буде завершено.
Значення, що повертається
Future — завершений Future з помилкою.
Приклади
Приклад #1 Створення Future з помилкою
<?php
use Async\Future;
$future = Future::failed(new \RuntimeException("Loading error"));
var_dump($future->isCompleted()); // bool(true)
try {
$future->await();
} catch (\RuntimeException $e) {
echo "Caught: " . $e->getMessage() . "\n";
// Caught: Loading error
}
Приклад #2 Використання для раннього повернення помилки
<?php
use Async\Future;
function connectToService(string $host): Future {
if (empty($host)) {
return Future::failed(
new \InvalidArgumentException("Host cannot be empty")
);
}
return \Async\async(function() use ($host) {
return performConnection($host);
});
}
$future = connectToService('');
$future->catch(function(\Throwable $e) {
echo "Error: " . $e->getMessage() . "\n";
});
Дивіться також
- Future::completed — Створити Future з результатом
- Future::catch — Обробити помилку Future
- Future::await — Очікувати результат