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

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

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

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

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

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

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

  • ArrayBlockingQueue和LinkedBlockingQueue异同点

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

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

相关推荐
William_cl4 分钟前
C# MVC 修复DataTable时间排序以及中英文系统的时间筛选问题
开发语言·c#·mvc
running thunderbolt4 分钟前
项目---网络通信组件JsonRpc
linux·服务器·c语言·开发语言·网络·c++·性能优化
玩毛线的包子19 分钟前
Android Gradle学习(十三)- 配置读取和文件写入
java
小马学嵌入式~28 分钟前
堆排序原理与实现详解
开发语言·数据结构·学习·算法
青岛少儿编程-王老师31 分钟前
CCF编程能力等级认证GESP—C++6级—20250927
java·c++·算法
SundayBear1 小时前
Qt 开发修炼指南:从入门到通透的实战心法
开发语言·qt·嵌入式
一條狗1 小时前
学习日报 20251007|深度解析:基于 Guava LoadingCache 的优惠券模板缓存设计与实现
java·oracle·loadingcache
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 64: 岛屿的最大面积、被围绕的区域
java·算法·leetcode·决策树·职场和发展·深度优先·推荐算法
_w_z_j_2 小时前
C++----bitmap位图的使用
开发语言·c++
Lisonseekpan2 小时前
Spring Boot 中使用 Caffeine 缓存详解与案例
java·spring boot·后端·spring·缓存