|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object edu.emory.mathcs.backport.java.util.concurrent.ExecutorCompletionService
A 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 Summary | |
ExecutorCompletionService(Executor executor)
Creates an ExecutorCompletionService using the supplied executor for base task execution and a LinkedBlockingQueue as a completion queue. |
|
ExecutorCompletionService(Executor executor,
BlockingQueue completionQueue)
Creates an ExecutorCompletionService using the supplied executor for base task execution and the supplied queue as its completion queue. |
Method Summary | |
Future |
poll()
Retrieves and removes the Future representing the next completed task or null if none are present. |
Future |
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 |
submit(Callable task)
Submits a value-returning task for execution and returns a Future representing the pending results of the task. |
Future |
submit(java.lang.Runnable task,
java.lang.Object result)
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. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
public ExecutorCompletionService(Executor executor)
LinkedBlockingQueue
as a completion queue.
executor
- the executor to use
java.lang.NullPointerException
- if executor is nullpublic ExecutorCompletionService(Executor executor, BlockingQueue completionQueue)
executor
- the executor to usecompletionQueue
- the queue to use as the completion queue
normally one dedicated for use by this service
java.lang.NullPointerException
- if executor or completionQueue are nullMethod Detail |
public Future submit(Callable task)
CompletionService
submit
in interface CompletionService
task
- the task to submit
public Future submit(java.lang.Runnable task, java.lang.Object result)
CompletionService
submit
in interface CompletionService
task
- the task to submitresult
- the result to return upon successful completion
public Future take() throws java.lang.InterruptedException
CompletionService
take
in interface CompletionService
java.lang.InterruptedException
- if interrupted while waitingpublic Future poll()
CompletionService
poll
in interface CompletionService
public Future poll(long timeout, TimeUnit unit) throws java.lang.InterruptedException
CompletionService
poll
in interface CompletionService
timeout
- how long to wait before giving up, in units of
unitunit
- a TimeUnit determining how to interpret the
timeout parameter
java.lang.InterruptedException
- if interrupted while waiting
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |