队列:第一章:阻塞队列

简介: 队列:第一章:阻塞队列

理论:

阻塞队列与普通队列的区别在于,当队列是空的时,从队列中获取元素的操作将会被阻塞,或者当队列是满时,往队列里添加元素的操作会被阻塞。试图从空的阻塞队列中获取元素的线程将会被阻塞,直到其他的线程往空的队列插入新的元素。同样,试图往已满的阻塞队列中添加新元素的线程同样也会被阻塞,直到其他的线程使队列重新变得空闲起来,如从队列中移除一个或者多个元素,或者完全清空队列,下图展示了如何通过阻塞队列来合作:



线程1往阻塞队列中添加元素,而线程2从阻塞队列中移除元素

常用的队列主要有以下两种:

(当然通过不同的实现方式,还可以延伸出很多不同类型的队列,DelayQueue就是其中的一种)


   先进先出(FIFO):先插入的队列的元素也最先出队列,类似于排队的功能。从某种程度上来说这种队列也体现了一种公平性。


   后进先出(LIFO):后插入队列的元素最先出队列,这种队列优先处理最近发生的事件。  

好处:

接口结构和实现类:

相关文章
|
3天前
|
存储 Java C++
Java集合篇之深度解析Queue,单端队列、双端队列、优先级队列、阻塞队列
Java集合篇之深度解析Queue,单端队列、双端队列、优先级队列、阻塞队列
26 0
|
3天前
|
存储 前端开发
快速掌握队列的基础知识
快速掌握队列的基础知识
|
3天前
|
安全 Java
队列的学习(三) 手写一个阻塞队列
队列的学习(三) 手写一个阻塞队列 本文将介绍如何手写一个阻塞队列。阻塞队列是一种线程安全的队列,当队列为空时,消费者线程将被阻塞直到队列中有元素可供消费;当队列已满时,生产者线程将被阻塞直到队列有空闲位置可供插入元素。
|
前端开发 算法
【数据结构与算法】队列-模拟实现队列以及设计循环队列
队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。 队列是一种先进先出的数据结构,注意和栈进行区分,不要记混.
|
存储 Java
Java数据结构之队列
队列是一个有序列表,可以用数组或是链表来实现。 遵循先入先出的原则。即:先存入队列的数据,要先取出。后存入的要后取出
97 0
|
Java 应用服务中间件
Java多线程案例之阻塞队列
Java多线程案例之阻塞队列
108 0
Java多线程案例之阻塞队列
|
安全 Java 容器
Java多线程案例——阻塞队列
阻塞队列是一种特殊的队列. 也遵守 “先进先出” 的原则.
113 0
Java多线程案例——阻塞队列
|
存储 安全 Java
Java多线程案例【阻塞队列】
Java多线程案例【阻塞队列】
Java多线程案例【阻塞队列】
|
存储 缓存 Java
JUC并发编程学习(十)-阻塞队列、同步队列
JUC并发编程学习(十)-阻塞队列、同步队列
JUC并发编程学习(十)-阻塞队列、同步队列
|
开发者 Python
队列的使用| 学习笔记
快速学习队列的使用
60 0