Class ExecutorCompletionService<V>
- java.lang.Object
-
- java.util.concurrent.ExecutorCompletionService<V>
-
- All Implemented Interfaces:
- CompletionService<V>
public class ExecutorCompletionService<V> extends Object implements CompletionService<V>
ACompletionService
that uses a suppliedExecutor
to execute tasks. This class arranges that submitted tasks are, upon completion, placed on a queue accessible usingtake
. The class is lightweight enough to be suitable for transient use when processing groups of tasks.Usage Examples. Suppose you have a set of solvers for a certain problem, each returning a value of some type
Result
, and would like to run them concurrently, processing the results of each of them that return a non-null value, in some methoduse(Result r)
. You could write this as:void solve(Executor e, Collection<Callable<Result>> solvers) throws InterruptedException, ExecutionException { CompletionService<Result> ecs = new ExecutorCompletionService<Result>(e); for (Callable<Result> s : solvers) ecs.submit(s); int n = solvers.size(); for (int i = 0; i < n; ++i) { Result r = ecs.take().get(); if (r != null) use(r); } }
void solve(Executor e, Collection<Callable<Result>> solvers) throws InterruptedException { CompletionService<Result> ecs = new ExecutorCompletionService<Result>(e); int n = solvers.size(); List<Future<Result>> futures = new ArrayList<Future<Result>>(n); Result result = null; try { for (Callable<Result> s : solvers) futures.add(ecs.submit(s)); for (int i = 0; i < n; ++i) { try { Result r = ecs.take().get(); if (r != null) { result = r; break; } } catch (ExecutionException ignore) {} } } finally { for (Future<Result> f : futures) f.cancel(true); } if (result != null) use(result); }
-
-
Constructor Summary
Constructors Constructor and Description ExecutorCompletionService(Executor executor)
Creates an ExecutorCompletionService using the supplied executor for base task execution and aLinkedBlockingQueue
as a completion queue.ExecutorCompletionService(Executor executor, BlockingQueue<Future<V>> completionQueue)
Creates an ExecutorCompletionService using the supplied executor for base task execution and the supplied queue as its completion queue.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method and Description Future<V>
poll()
Retrieves and removes the Future representing the next completed task, ornull
if none are present.Future<V>
poll(long timeout, TimeUnit unit)
Retrieves and removes the Future representing the next completed task, waiting if necessary up to the specified wait time if none are yet present.Future<V>
submit(Callable<V> task)
Submits a value-returning task for execution and returns a Future representing the pending results of the task.Future<V>
submit(Runnable task, V result)
Submits a Runnable task for execution and returns a Future representing that task.Future<V>
take()
Retrieves and removes the Future representing the next completed task, waiting if none are yet present.
-
-
-
Constructor Detail
ExecutorCompletionService
public ExecutorCompletionService(Executor executor)
Creates an ExecutorCompletionService using the supplied executor for base task execution and aLinkedBlockingQueue
as a completion queue.- Parameters:
-
executor
- the executor to use - Throws:
-
NullPointerException
- if executor isnull
ExecutorCompletionService
public ExecutorCompletionService(Executor executor, BlockingQueue<Future<V>> completionQueue)
Creates an ExecutorCompletionService using the supplied executor for base task execution and the supplied queue as its completion queue.- Parameters:
-
executor
- the executor to use -
completionQueue
- the queue to use as the completion queue normally one dedicated for use by this service. This queue is treated as unbounded -- failed attemptedQueue.add
operations for completed tasks cause them not to be retrievable. - Throws:
-
NullPointerException
- if executor or completionQueue arenull
-
Method Detail
submit
public Future<V> submit(Callable<V> task)
Description copied from interface:CompletionService
Submits a value-returning task for execution and returns a Future representing the pending results of the task. Upon completion, this task may be taken or polled.- Specified by:
-
submit
in interfaceCompletionService<V>
- Parameters:
-
task
- the task to submit - Returns:
- a Future representing pending completion of the task
submit
public Future<V> submit(Runnable task, V result)
Description copied from interface:CompletionService
Submits a Runnable task for execution and returns a Future representing that task. Upon completion, this task may be taken or polled.- Specified by:
-
submit
in interfaceCompletionService<V>
- Parameters:
-
task
- the task to submit -
result
- the result to return upon successful completion - Returns:
-
a Future representing pending completion of the task, and whose
get()
method will return the given result value upon completion
take
public Future<V> take() throws InterruptedException
Description copied from interface:CompletionService
Retrieves and removes the Future representing the next completed task, waiting if none are yet present.- Specified by:
-
take
in interfaceCompletionService<V>
- Returns:
- the Future representing the next completed task
- Throws:
-
InterruptedException
- if interrupted while waiting
poll
public Future<V> poll()
Description copied from interface:CompletionService
Retrieves and removes the Future representing the next completed task, ornull
if none are present.- Specified by:
-
poll
in interfaceCompletionService<V>
- Returns:
-
the Future representing the next completed task, or
null
if none are present
poll
public Future<V> poll(long timeout, TimeUnit unit) throws InterruptedException
Description copied from interface:CompletionService
Retrieves and removes the Future representing the next completed task, waiting if necessary up to the specified wait time if none are yet present.- Specified by:
-
poll
in interfaceCompletionService<V>
- Parameters:
-
timeout
- how long to wait before giving up, in units ofunit
-
unit
- aTimeUnit
determining how to interpret thetimeout
parameter - Returns:
-
the Future representing the next completed task or
null
if the specified waiting time elapses before one is present - Throws:
-
InterruptedException
- if interrupted while waiting
-
Submit a bug or feature
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 1993, 2022, Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.