|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Object![]()
![]()
![]()
java.util.concurrent.ExecutorCompletionService<V>
<V>public class ExecutorCompletionService<V>

<V>
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
Creates an ExecutorCompletionService using the supplied executor for base task execution and a LinkedBlockingQueue as a completion queue. |
|
ExecutorCompletionService
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
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
Submits a value-returning task for execution and returns a Future representing the pending results of the task. |
Future |
submit
Submits a Runnable task for execution and returns a Future representing that task.Upon completion, this task may be taken or polled. |
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 |
| Constructor Detail |
|---|

public ExecutorCompletionService(Executor![]()
![]()
executor)
LinkedBlockingQueue
as a completion queue.
executor - the executor to use
NullPointerException

- if executor is null

public ExecutorCompletionService(Executor![]()
![]()
executor, BlockingQueue
![]()
![]()
<Future
![]()
![]()
<V>> completionQueue)
executor - the executor to usecompletionQueue - the queue to use as the completion queue
normally one dedicated for use by this service
NullPointerException

- if executor or completionQueue are null| Method Detail |
|---|

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 submitresult - the result to return upon successful completion

public Future![]()
![]()
<V> take() throws InterruptedException
![]()
![]()
CompletionService

take

in interface CompletionService
<V>InterruptedException

- if interrupted while waiting.

public Future![]()
![]()
<V> poll()
CompletionService

poll

in interface CompletionService
<V>

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
unitunit - a TimeUnit determining how to interpret the
timeout parameter
InterruptedException

- if interrupted while waiting.
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||