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

任务的提交者和执行者
专门用来执行任务的实现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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值