- Enclosing class:
- Futures
ListenableFuture whose result is generated from a combination
of input futures.
See Futures.whenAllComplete(ListenableFuture...) and Futures.whenAllSucceed(ListenableFuture...) 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
- Author:
- Kevin Bourrillion, Nishant Thakkar, Sven Mawson
- 
Method SummaryModifier and TypeMethodDescription<C extends @Nullable Object>
 ListenableFuture<C> Creates theListenableFuturewhich will return the result of callingCallable.call()incombinerwhen all futures complete, using the specifiedexecutor.<C extends @Nullable Object>
 ListenableFuture<C> callAsync(AsyncCallable<C> combiner, Executor executor) Creates theListenableFuturewhich will return the result of callingAsyncCallable.call()incombinerwhen all futures complete, using the specifiedexecutor.Creates theListenableFuturewhich will return the result of runningcombinerwhen all Futures complete.
- 
Method Details- 
callAsyncpublic <C extends @Nullable Object> 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. - Returns:
- a future whose result is based on combiner(or based on the input futures passed towhenAllSucceed, if that is the method you used to create thisFutureCombiner). Even if you don't care about the value of the future, you should typically check whether it failed: See https://errorprone.info/bugpattern/FutureReturnValueIgnored.
 
- 
callpublic <C extends @Nullable Object> 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. - Returns:
- a future whose result is based on combiner(or based on the input futures passed towhenAllSucceed, if that is the method you used to create thisFutureCombiner). Even if you don't care about the value of the future, you should typically check whether it failed: See https://errorprone.info/bugpattern/FutureReturnValueIgnored.
 
- 
runCreates 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. - Returns:
- a future whose result is based on combiner(or based on the input futures passed towhenAllSucceed, if that is the method you used to create thisFutureCombiner). Even though the future never produces a value other thannull, you should typically check whether it failed: See https://errorprone.info/bugpattern/FutureReturnValueIgnored.
- Since:
- 23.6
 
 
-