阻塞队列的原理?(如何设计一个阻塞队列?)

  • 阻塞队列主要是用于插入和获取的操作

    • 当阻塞队列满了的时候,插入操作会被阻塞,直到队列有空位。
    • 当阻塞队列为空的时候,获取操作也会被阻塞,直到队列有数据。
  • ArrayBlockingQueue :有界队列,底层基于数组实现,初始化时指定队列的大小,队列满时,生产者被阻塞,队列为空时,消费者被阻塞。

  • LinkedBlockingQueue :可以有界,也可以无界,底层基于链表实现,无界队列,就可以一直往里添加元素,直到资源耗尽。

  • PriorityBlockingQueue :无界队列,有优先级顺序,元素按照自然顺序或指定比较器的顺序排序

  • DelayQueue : 无界队列,队列中的元素需实现delay的接口,只有当元素延迟时间到期时,才能被取出,常用延迟调度任务,缓存失效

  • SynchronousQueue 不存储任务,指用于线程间传递任务。

  • ArrayBlockingQueue和LinkedBlockingQueue异同点

|-------------------------|-------------------------|
| ArrayBlocking Queue | LinkedBlocking Queue |
| 数组 | 链表 |
| 有界 | 有界/无界 |
| ReentrantLock Condition | ReentrantLock Condition |
| 一把锁 | 放/取两把锁 |

因为LinkedBlockingQueue有放,取两把锁,因此它的吞吐量要比ArrayBlockingQueue高

相关推荐
月落归舟4 小时前
深入剖析乐观锁背后的原理
java·乐观锁
SimonKing4 小时前
OpenCode 在 IDEA 中使用 ACP 协议 VS 直接使用 TUI,哪个编程方式更是你的菜?
java·后端·程序员
NE_STOP4 小时前
Redis--持久化之AOF
java
budingxiaomoli4 小时前
注册中心的其他实现-Nacos
java·spring cloud·微服务
大大大大晴天️4 小时前
Flink技术实践-Flink重启策略选型指南
java·大数据·flink
szial4 小时前
Python Click 教程:从函数到专业命令行工具
开发语言·python
Karle_4 小时前
为AI编辑器准备c++编译环境,onnxruntime、cmake、cl,网上坑太多备份记录后续方便使用。
开发语言·c++·编辑器
Dxy12393102164 小时前
JavaScript 字符串转数值(小数)
开发语言·javascript·ecmascript
ffqws_4 小时前
Spring @Transactional 注解详解:从入门到避坑
java·数据库·后端·spring
yu85939585 小时前
matlab实现ARMA(自回归移动平均)模型
开发语言·matlab·回归