public class ExecutionCompletionService<V>
extends java.lang.Object
implements java.util.concurrent.CompletionService<V>
CompletionService
that uses a supplied ExecutionService
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.
This class must be used instead of a ExecutorCompletionService
provided from java.util.concurrent package. The
ExecutorCompletionService
may not be used since it requires the use
of a non serializable RunnableFuture object. Since a ExecutionService
may only be used with serializable request objects, this class must be used
instead.
限定符和类型 | 类和说明 |
---|---|
protected class |
ExecutionCompletionService.QueueingListener |
限定符和类型 | 字段和说明 |
---|---|
protected java.util.concurrent.BlockingQueue<NotifyingFuture<V>> |
completionQueue |
protected ExecutionService |
executor |
protected ExecutionCompletionService.QueueingListener |
listener |
限定符 | 构造器和说明 |
---|---|
|
ExecutionCompletionService(ExecutionService executor)
Creates an ExecutorCompletionService using the supplied
executor for base task execution and a
LinkedBlockingQueue as a completion queue. |
|
ExecutionCompletionService(ExecutionService executor,
java.util.concurrent.BlockingQueue<NotifyingFuture<V>> completionQueue)
Creates an ExecutorCompletionService using the supplied
executor for base task execution and the supplied queue as its
completion queue.
|
protected |
ExecutionCompletionService(ExecutionService executor,
java.util.concurrent.BlockingQueue<NotifyingFuture<V>> completionQueue,
ExecutionCompletionService.QueueingListener listener)
This constructor is here if someone wants to override this class and
provide their own QueueingListener to possibly listen in on futures
being finished
|
限定符和类型 | 方法和说明 |
---|---|
NotifyingFuture<V> |
poll()
This future may safely be used as a NotifyingFuture if desired.
|
NotifyingFuture<V> |
poll(long timeout,
java.util.concurrent.TimeUnit unit)
This future may safely be used as a NotifyingFuture if desired.
|
java.util.concurrent.Future<V> |
submit(java.util.concurrent.Callable<V> task)
This future object may not be used as a NotifyingFuture.
|
java.util.concurrent.Future<V> |
submit(java.lang.Runnable task,
V result)
This future object may not be used as a NotifyingFuture.
|
NotifyingFuture<V> |
take()
This future may safely be used as a NotifyingFuture if desired.
|
protected final ExecutionService executor
protected final java.util.concurrent.BlockingQueue<NotifyingFuture<V>> completionQueue
protected final ExecutionCompletionService.QueueingListener listener
public ExecutionCompletionService(ExecutionService executor)
LinkedBlockingQueue
as a completion queue.executor
- the executor to usejava.lang.NullPointerException
- if executor is nullpublic ExecutionCompletionService(ExecutionService executor, java.util.concurrent.BlockingQueue<NotifyingFuture<V>> completionQueue)
executor
- the executor to usecompletionQueue
- the queue to use as the completion queue
normally one dedicated for use by this servicejava.lang.NullPointerException
- if executor is nullprotected ExecutionCompletionService(ExecutionService executor, java.util.concurrent.BlockingQueue<NotifyingFuture<V>> completionQueue, ExecutionCompletionService.QueueingListener listener)
executor
- the executor to usecompletionQueue
- the queue to use as the completion queue
normally one dedicated for use by this servicelistener
- the listener to notify. To work properly this listner
should at minimum call the super.futureDone or else this
completion service may not work correctly.java.lang.NullPointerException
- if executor is nullpublic java.util.concurrent.Future<V> submit(java.util.concurrent.Callable<V> task)
This future object may not be used as a NotifyingFuture. That is because internally this class sets the listener to provide ability to add to the queue.
submit
在接口中 java.util.concurrent.CompletionService<V>
public java.util.concurrent.Future<V> submit(java.lang.Runnable task, V result)
This future object may not be used as a NotifyingFuture. That is because internally this class sets the listener to provide ability to add to the queue.
submit
在接口中 java.util.concurrent.CompletionService<V>
public NotifyingFuture<V> take() throws java.lang.InterruptedException
This future may safely be used as a NotifyingFuture if desired. This is because if it tries to set a listener it will be called immediately since the task has already been completed.
take
在接口中 java.util.concurrent.CompletionService<V>
java.lang.InterruptedException
public NotifyingFuture<V> poll()
This future may safely be used as a NotifyingFuture if desired. This is because if it tries to set a listener it will be called immediately since the task has already been completed.
poll
在接口中 java.util.concurrent.CompletionService<V>
public NotifyingFuture<V> poll(long timeout, java.util.concurrent.TimeUnit unit) throws java.lang.InterruptedException
This future may safely be used as a NotifyingFuture if desired. This is because if it tries to set a listener it will be called immediately since the task has already been completed.
poll
在接口中 java.util.concurrent.CompletionService<V>
java.lang.InterruptedException