public class ExecutorCompletionService<V> extends Objectimplements CompletionService <V>
CompletionService that uses a supplied
Executor to execute tasks. This class arranges that submitted tasks are, upon completion, placed on a queue accessible using
take. 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 method use(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); } } Suppose instead that you would like to use the first non-null result of the set of tasks, ignoring any that encounter exceptions, and cancelling all other tasks when the first one is ready:
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 and Description |
|---|
ExecutorCompletionService(Executor
Creates an ExecutorCompletionService using the supplied executor for base task execution and a
LinkedBlockingQueue as a completion queue.
|
ExecutorCompletionService(Executor
Creates an ExecutorCompletionService using the supplied executor for base task execution and the supplied queue as its completion queue.
|
| Modifier and Type | Method and Description |
|---|---|
Future |
poll()
Retrieves and removes the Future representing the next completed task, or
null if none are present.
|
Future |
poll(long timeout, TimeUnit
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 |
submit(Callable
Submits a value-returning task for execution and returns a Future representing the pending results of the task.
|
Future |
submit(Runnable
Submits a Runnable task for execution and returns a Future representing that task.
|
Future |
take()
Retrieves and removes the Future representing the next completed task, waiting if none are yet present.
|
public ExecutorCompletionService(Executorexecutor)
LinkedBlockingQueue as a completion queue.
executor - the executor to use
NullPointerException - if executor is
null
public ExecutorCompletionService(Executorexecutor, BlockingQueue <Future <V>> completionQueue)
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 attempted
Queue.add operations for completed tasks cause them not to be retrievable.
NullPointerException - if executor or completionQueue are
null
public Future<V> submit(Callable <V> task)
CompletionService
submit in interface
CompletionService<V>
task - the task to submit
public Future<V> submit(Runnable task, V result)
CompletionService
submit in interface
CompletionService<V>
task - the task to submit
result - the result to return upon successful completion
get() method will return the given result value upon completion
public Future<V> take() throws InterruptedException
CompletionService
take in interface
CompletionService<V>
InterruptedException - if interrupted while waiting
public Future<V> poll()
CompletionService
null if none are present.
poll in interface
CompletionService<V>
null if none are present
public Future<V> poll(long timeout, TimeUnit unit) throws InterruptedException
CompletionService
poll in interface
CompletionService<V>
timeout - how long to wait before giving up, in units of
unit
unit - a
TimeUnit determining how to interpret the
timeout parameter
null if the specified waiting time elapses before one is present
InterruptedException - if interrupted while waiting