任务的提交者和执行者
专门用来执行任务的实现Executor是方便并发执行任务,任务提交者不需要再创建管理线程,使用更方便,也减少了开销。
java.util.concurrent.Executors是Executor的工厂类,通过Executors可以创建你所需要的 Executor。
任务的提交者和执行者之间的通讯
Future
cancel(boolean):boolean
isCancelled():boolean
isDone():boolean
get():T
get(long,TimeUnit):T
有两种任务Runnable、Callable
Callable是需要返回值得任务
Task Submitter把任务提交给Executor执行,他们之间需要通信,这种具体实现是用的Future
Future(可用于异步变同步)中有get(阻塞至任务完成)、cancle、get(timeout)(等待一段时间)
阻塞队列
阻塞队列,是一种常用的并发数据结构,常用于生产者-消费者模式。 在Java中,有三种常用的阻塞队列:
ArrayBlockingQueue LinkedBlockingQueue SynchronousQueue
使用阻塞队列
Queue
add(E) : boolean offer() : boolean remove() : E poll() : E element() : E peek() : E
使用BlockingQueue的时候,尽量不要使用从Queue继承下来的 方法,否则就失去了Blocking的特性了。
BlockingQueue
put(E) take() : E
offer(E, long, TimeUnit) : boolean
poll(long, TimeUnit) : E
remainingCapacity()
drainTo(Collection