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

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

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

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

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

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

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

  • ArrayBlockingQueue和LinkedBlockingQueue异同点

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

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

相关推荐
麒qiqi2 分钟前
【Linux 系统编程】文件 IO 与 Makefile 核心实战:从系统调用到工程编译
java·前端·spring
hoiii1872 分钟前
MATLAB实现HOG特征提取与SVM行人检测
开发语言·支持向量机·matlab
en-route13 分钟前
Spring 框架下 Redis 会话存储应用实践
java·redis·spring
JIngJaneIL14 分钟前
基于Java酒店管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
颜颜yan_22 分钟前
DevUI自定义开发实践:从零开始构建自定义组件和插件
android·java·数据库
ZC·Shou23 分钟前
Rust 之二 各组件工具的源码、构建、配置、使用(二)
开发语言·ide·rust·工具·命令·clippy·rustfmt
沐知全栈开发27 分钟前
SQLite Limit 子句详解
开发语言
带刺的坐椅28 分钟前
Java 低代码平台的“动态引擎”:Liquor
java·javascript·低代码·groovy·liquor
资深web全栈开发30 分钟前
Go语言从1.18到1.25版本功能更新详解
开发语言·后端·golang
想用offer打牌33 分钟前
JDK动态代理为什么基于接口而不基于类?
java·后端·面试