您的位置:首页 > 编程语言 > Java开发

Java并发(2)(未整理完待会回家整理)

2016-07-28 18:21 483 查看
任务的提交者和执行者

专门用来执行任务的实现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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: