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

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

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

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

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

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

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

  • ArrayBlockingQueue和LinkedBlockingQueue异同点

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

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

相关推荐
W13330908907几秒前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
kyle~7 分钟前
Python---watchdog文件系统监控库
开发语言·python·操作系统·文件系统
JavaLearnerZGQ8 分钟前
Spring Boot 流式响应接口核心组件解析
java·spring boot·后端
cur1es9 分钟前
【TCP 协议的相关特性】
java·网络·网络协议·tcp/ip·tcp·滑动窗口·连接管理
山岚的运维笔记13 分钟前
SQL Server笔记 -- 第80章:分页
java·数据库·笔记·sql·microsoft·sqlserver
开开心心就好20 分钟前
文字转语音无字数限,对接微软接口比付费爽
java·linux·开发语言·人工智能·pdf·语音识别
海兰21 分钟前
Elasticsearch 9.x Java 异步客户端
java·elasticsearch·jenkins
马猴烧酒.22 分钟前
【JAVA算法|hot100】哈希类型题目详解笔记
java·笔记
xyq202423 分钟前
Perl 发送邮件:全面指南
开发语言
cui_ruicheng24 分钟前
C++ 继承(下):多继承、菱形继承与虚继承
开发语言·c++