Java进阶:BlockingQueue阻塞队列的使用

1. 概述

相比平时讨论的队列,阻塞队列增加了阻塞的功能:

  • 当有限长度的队列填满了数据时,继续往队列添加数据的线程将被阻塞住,持续等待,直到超时或队列数据被消费而腾出空间
  • 当队列数据为空时,消费线程会因为取不到数据而被阻塞,直到生产线程往队列添加数据,此时成功取到数据而不再阻塞

2. 常用的阻塞队列

  • ArrayBlockingQueue:由数组结构组成的有界阻塞队列,底层的出入队由同一个ReentrantLock加锁控制,可以传递fair参数指定使用公平锁 or 非公平锁
  • LinkedBlockingQueue:由链表结构组成的有界阻塞队列(容量默认是Integer.MAX_VALUE,因此也可以理解成无界)。其出入队由不同的ReentrantLock控制,因此性能优于ArrayBlockingQueue
  • SynchronousQueue:只存储一个元素的阻塞队列,容量大小只有1

3. 操作方法

<
方法类型 抛出异常 特殊值 阻塞 超时
添加 add(e) offer(e) put() offer(e,time,unit)
移除 remove() poll() take() poll(time,unit)
获取
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

°Fuhb

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值