| java.lang.Object | |
| ↳ | java.util.concurrent.ExecutorCompletionService<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);
    }
 
| Public Constructors | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
| Creates an ExecutorCompletionService using the supplied
executor for base task execution and a
LinkedBlockingQueue as a completion queue. | |||||||||||
| Creates an ExecutorCompletionService using the supplied
executor for base task execution and the supplied queue as its
completion queue. | |||||||||||
| Public Methods | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
| Retrieves and removes the Future representing the next
completed task, waiting if necessary up to the specified wait
time if none are yet present. | |||||||||||
| Retrieves and removes the Future representing the next
completed task or null if none are present. | |||||||||||
| Submits a value-returning task for execution and returns a Future
representing the pending results of the task. | |||||||||||
| Submits a Runnable task for execution and returns a Future
representing that task. | |||||||||||
| Retrieves and removes the Future representing the next
completed task, waiting if none are yet present. | |||||||||||
| [Expand] Inherited Methods | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
|  From class java.lang.Object | |||||||||||
|  From interface java.util.concurrent.CompletionService | |||||||||||
Creates an ExecutorCompletionService using the supplied executor for base task execution and a LinkedBlockingQueue as a completion queue.
| executor | the executor to use | 
|---|
| NullPointerException | if executor is null | 
|---|
Creates an ExecutorCompletionService using the supplied executor for base task execution and the supplied queue as its completion queue.
| executor | the executor to use | 
|---|---|
| completionQueue | the queue to use as the completion queue normally one dedicated for use by this service | 
| NullPointerException | if executor or completionQueue are null | 
|---|
Retrieves and removes the Future representing the next completed task, waiting if necessary up to the specified wait time if none are yet present.
| timeout | how long to wait before giving up, in units of unit | 
|---|---|
| unit | a TimeUnit determining how to interpret the timeout parameter | 
| InterruptedException | 
|---|
Retrieves and removes the Future representing the next completed task or null if none are present.
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.
| task | the task to submit | 
|---|
Submits a Runnable task for execution and returns a Future representing that task. Upon completion, this task may be taken or polled.
| task | the task to submit | 
|---|---|
| result | the result to return upon successful completion | 
Retrieves and removes the Future representing the next completed task, waiting if none are yet present.
| InterruptedException | 
|---|