Interface ListeningExecutorService
-
- All Superinterfaces:
Executor
,ExecutorService
- All Known Subinterfaces:
ListeningScheduledExecutorService
- All Known Implementing Classes:
AbstractListeningExecutorService
,ForwardingListeningExecutorService
@DoNotMock("Use TestingExecutors.sameThreadScheduledExecutor, or wrap a real Executor from java.util.concurrent.Executors with MoreExecutors.listeningDecorator") @GwtIncompatible public interface ListeningExecutorService extends ExecutorService
AnExecutorService
that returnsListenableFuture
instances. To create an instance from an existingExecutorService
, callMoreExecutors.listeningDecorator(ExecutorService)
.- Since:
- 10.0
- Author:
- Chris Povirk
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description <T extends @Nullable Object>
List<Future<T>>invokeAll(Collection<? extends Callable<T>> tasks)
<T extends @Nullable Object>
List<Future<T>>invokeAll(Collection<? extends Callable<T>> tasks, long timeout, TimeUnit unit)
ListenableFuture<?>
submit(Runnable task)
<T extends @Nullable Object>
ListenableFuture<T>submit(Runnable task, T result)
<T extends @Nullable Object>
ListenableFuture<T>submit(Callable<T> task)
-
Methods inherited from interface java.util.concurrent.ExecutorService
awaitTermination, invokeAny, invokeAny, isShutdown, isTerminated, shutdown, shutdownNow
-
-
-
-
Method Detail
-
submit
<T extends @Nullable Object> ListenableFuture<T> submit(Callable<T> task)
- Specified by:
submit
in interfaceExecutorService
- Returns:
- a
ListenableFuture
representing pending completion of the task - Throws:
RejectedExecutionException
-
submit
ListenableFuture<?> submit(Runnable task)
- Specified by:
submit
in interfaceExecutorService
- Returns:
- a
ListenableFuture
representing pending completion of the task - Throws:
RejectedExecutionException
-
submit
<T extends @Nullable Object> ListenableFuture<T> submit(Runnable task, T result)
- Specified by:
submit
in interfaceExecutorService
- Returns:
- a
ListenableFuture
representing pending completion of the task - Throws:
RejectedExecutionException
-
invokeAll
<T extends @Nullable Object> List<Future<T>> invokeAll(Collection<? extends Callable<T>> tasks) throws InterruptedException
All elements in the returned list must be
ListenableFuture
instances. The easiest way to obtain aList<ListenableFuture<T>>
from this method is an unchecked (but safe) cast:@SuppressWarnings("unchecked") // guaranteed by invokeAll contract
List<ListenableFuture<T>> futures = (List) executor.invokeAll(tasks);
- Specified by:
invokeAll
in interfaceExecutorService
- Returns:
- A list of
ListenableFuture
instances representing the tasks, in the same sequential order as produced by the iterator for the given task list, each of which has completed. - Throws:
RejectedExecutionException
NullPointerException
- if any task is nullInterruptedException
-
invokeAll
<T extends @Nullable Object> List<Future<T>> invokeAll(Collection<? extends Callable<T>> tasks, long timeout, TimeUnit unit) throws InterruptedException
All elements in the returned list must be
ListenableFuture
instances. The easiest way to obtain aList<ListenableFuture<T>>
from this method is an unchecked (but safe) cast:@SuppressWarnings("unchecked") // guaranteed by invokeAll contract
List<ListenableFuture<T>> futures = (List) executor.invokeAll(tasks, timeout, unit);
- Specified by:
invokeAll
in interfaceExecutorService
- Returns:
- a list of
ListenableFuture
instances representing the tasks, in the same sequential order as produced by the iterator for the given task list. If the operation did not time out, each task will have completed. If it did time out, some of these tasks will not have completed. - Throws:
RejectedExecutionException
NullPointerException
- if any task is nullInterruptedException
-
-