public class AsyncResult<V> extends Object implements ListenableFuture<V>
Future handle that can be used for method signatures
which are declared with a Future return type for asynchronous execution.
As of Spring 4.1, this class implements ListenableFuture, not just
plain Future, along with the corresponding support
in @Async processing.
As of Spring 4.2, this class also supports passing execution exceptions back to the caller.
Async,
forValue(Object),
forExecutionException(Throwable)| Constructor and Description |
|---|
AsyncResult(V value)
Create a new AsyncResult holder.
|
| Modifier and Type | Method and Description |
|---|---|
void |
addCallback(ListenableFutureCallback<? super V> callback)
Registers the given callback to this
ListenableFuture. |
void |
addCallback(SuccessCallback<? super V> successCallback,
FailureCallback failureCallback)
Registers the given success and failure callbacks to this
ListenableFuture. |
boolean |
cancel(boolean mayInterruptIfRunning) |
static <V> ListenableFuture<V> |
forExecutionException(Throwable ex)
Create a new async result which exposes the given exception as an
ExecutionException from Future.get(). |
static <V> ListenableFuture<V> |
forValue(V value)
Create a new async result which exposes the given value from
Future.get(). |
V |
get() |
V |
get(long timeout,
TimeUnit unit) |
boolean |
isCancelled() |
boolean |
isDone() |
public AsyncResult(V value)
value - the value to pass throughpublic boolean cancel(boolean mayInterruptIfRunning)
public boolean isCancelled()
isCancelled in interface Future<V>public V get() throws ExecutionException
get in interface Future<V>ExecutionExceptionpublic V get(long timeout, TimeUnit unit) throws ExecutionException
get in interface Future<V>ExecutionExceptionpublic void addCallback(ListenableFutureCallback<? super V> callback)
ListenableFutureListenableFuture. The callback will
be triggered when this Future is complete or, if it is already complete,
immediately.addCallback in interface ListenableFuture<V>callback - the callback to registerpublic void addCallback(SuccessCallback<? super V> successCallback, FailureCallback failureCallback)
ListenableFutureListenableFuture.
The callback will be triggered when this Future is complete or, if it is
already complete immediately. This is a Java 8 lambdas compliant alternative to
ListenableFuture.addCallback(ListenableFutureCallback).addCallback in interface ListenableFuture<V>successCallback - the success callback to registerfailureCallback - the failure callback to registerpublic static <V> ListenableFuture<V> forValue(V value)
Future.get().value - the value to exposeFuture.get()public static <V> ListenableFuture<V> forExecutionException(Throwable ex)
ExecutionException from Future.get().ex - the exception to expose (either an pre-built ExecutionException
or a cause to be wrapped in an ExecutionException)ExecutionException