Class Futures.FutureCombiner<V>
- java.lang.Object
-
- com.google.common.util.concurrent.Futures.FutureCombiner<V>
-
- Enclosing class:
- Futures
@Beta @CanIgnoreReturnValue @GwtCompatible public static final class Futures.FutureCombiner<V> extends Object
A helper to create a newListenableFuturewhose result is generated from a combination of input futures.See
Futures.whenAllComplete(com.google.common.util.concurrent.ListenableFuture<? extends V>...)andFutures.whenAllSucceed(com.google.common.util.concurrent.ListenableFuture<? extends V>...)for how to instantiate this class.Example:
final ListenableFuture<Instant> loginDateFuture = loginService.findLastLoginDate(username); final ListenableFuture<List<String>> recentCommandsFuture = recentCommandsService.findRecentCommands(username); ListenableFuture<UsageHistory> usageFuture = Futures.whenAllSucceed(loginDateFuture, recentCommandsFuture) .call( () -> new UsageHistory( username, Futures.getDone(loginDateFuture), Futures.getDone(recentCommandsFuture)), executor);- Since:
- 20.0
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description <C> ListenableFuture<C>call(Callable<C> combiner, Executor executor)Creates theListenableFuturewhich will return the result of callingCallable.call()incombinerwhen all futures complete, using the specifiedexecutor.<C> ListenableFuture<C>callAsync(AsyncCallable<C> combiner, Executor executor)Creates theListenableFuturewhich will return the result of callingAsyncCallable.call()incombinerwhen all futures complete, using the specifiedexecutor.ListenableFuture<?>run(Runnable combiner, Executor executor)Creates theListenableFuturewhich will return the result of runningcombinerwhen all Futures complete.
-
-
-
Method Detail
-
callAsync
public <C> ListenableFuture<C> callAsync(AsyncCallable<C> combiner, Executor executor)
Creates theListenableFuturewhich will return the result of callingAsyncCallable.call()incombinerwhen all futures complete, using the specifiedexecutor.If the combiner throws a
CancellationException, the returned future will be cancelled.If the combiner throws an
ExecutionException, the cause of the thrownExecutionExceptionwill be extracted and returned as the cause of the newExecutionExceptionthat gets thrown by the returned combined future.Canceling this future will attempt to cancel all the component futures.
-
call
@CanIgnoreReturnValue public <C> ListenableFuture<C> call(Callable<C> combiner, Executor executor)
Creates theListenableFuturewhich will return the result of callingCallable.call()incombinerwhen all futures complete, using the specifiedexecutor.If the combiner throws a
CancellationException, the returned future will be cancelled.If the combiner throws an
ExecutionException, the cause of the thrownExecutionExceptionwill be extracted and returned as the cause of the newExecutionExceptionthat gets thrown by the returned combined future.Canceling this future will attempt to cancel all the component futures.
-
run
public ListenableFuture<?> run(Runnable combiner, Executor executor)
Creates theListenableFuturewhich will return the result of runningcombinerwhen all Futures complete.combinerwill run usingexecutor.If the combiner throws a
CancellationException, the returned future will be cancelled.Canceling this Future will attempt to cancel all the component futures.
- Since:
- 23.6
-
-