几种常见的阻塞队列

ArrayBlockingQueue

 底层维护了一个定长的数组,在生产者生产数据和消费者消费消费数据,共用同一个锁对象。


LinkedBlockingQueue

 底层维护了一个链表,当生产者线程往队列中生产数据时,消费者线程同时消费队列中的数据,
 原因就是生产者和消费者采用了额独立的锁来控制数据的同步。


关于ArrayBlockingQueue和LinkedBlockingQueue的异同,请移步我的另一篇博客:https://blog.csdn.net/weixin_43729854/article/details/107882990


SynchrousQueue

 天然实现了生产者和消费者,只作为中转者。


DelayQueue

其中的元素只有当指定的延迟时间到了,才能够从队列中获取元素。


PriorityBlockingQueue

基于优先级的阻塞队列,优先级的判断需要通过构造函数传入的Compartor对象决定,
注意的是其不会阻塞生产者线程,而只会在没有数据可消费时,阻塞消费者线程


核心方法

  1. offer(obj) 返回true/false
  2. offer(obj, timeout)  可以设定等待的时间,如果在指定的时间内,不能添加则会返回失败
  3. put(obj)  阻塞方法
  4. poll(time) 到达time仍然获取不到返回null
  5. poll(timeout, unit) 如果在指定时间内,队列一旦有数据则立即返回,反之时间超时还没有数据,则返回失败
  6. take() 阻塞方法
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值