java 并发编程之 BlockingQueue(阻塞队列)

BlockingQueue是Queue的一种线程安全的实现方式,其除了加了线程锁之外,还提供了一些阻塞等待的接口方法,供更多的功能实现方式。

BlockingQueue作为一个阻塞等待队列,其最常用的方法:

其内部成员主要我们可以从源码中看到

其包含一个线程锁,和两个condition对象。

队列,有着队头和队尾,我们可以很自然的可以联想到,队头消费,队尾生产,而BlockingQueue阻塞的特点更好的为我们的联想进行实现,消费者在队内无元素的时候阻塞等待生产者入队,一直如此。

因此BlockingQueue的最为典型的使用实例,便是生产者-消费者模式:

生产者。不断往队列中加入元素:

消费者,不断取出队头元素,无元素是阻塞等待

service层:

总结,BlockingQueue继承了Queue,为Queue的方法加上了并发安全锁,同时提供了部分阻塞等待的接口方法,更加的便捷。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值