数据可视化-Queue-队列

Queue (队列)

​ Queue:队列,遵循 FIFO (先进先出) 原则的数据结构, 接口与 List、Set 同一级,都是继承了 Collection 接口。LinkedList 实现了 Deque 接口

常用的类关系图:

在这里插入图片描述

AbstractQueue 非阻塞队列

实现了java.util.Queue接口和java.util.AbstractQueue接口

  • PriorityQueue 类实质上维护了一个有序列表。加入到 Queue 中的元素根据它们的天然排序(通过其 java.util.Comparable 实现)或者根据传递给构造函数的 java.util.Comparator 实现来定位。
  • ConcurrentLinkedQueue 是基于链接节点的、线程安全的队列。并发访问不需要同步。因为它在队列的尾部添加元素并从头部删除它们,所以只要不需要知道队列的大小,ConcurrentLinkedQueue 对公共集合的共享访问就可以工作得很好。收集关于队列大小的信息会很慢,需要遍历队列。

BlockingQuere 阻塞队列

java.util.concurrent 中加入了 BlockingQueue 接口和五个阻塞队列类。它实质上就是一种带有一点扭曲的 FIFO 数据结构。不是立即从队列中添加或者删除元素,线程执行操作阻塞,直到有空间或者元素可用。

  • ArrayBlockingQueue :一个由数组支持的有界队列。
  • LinkedBlockingQueue :一个由链接节点支持的可选有界队列。
  • PriorityBlockingQueue :一个由优先级堆支持的无界优先级队列。
  • DelayQueue :一个由优先级堆支持的、基于时间的调度队列。
  • SynchronousQueue :一个利用 BlockingQueue 接口的简单聚集(rendezvous)机制。

Deque 双端队列

Deque的含义是 “double ended queue”即双端队列,Deque 是一种具有队列和栈的性质的数据结构。双端队列中的元素可以从两端弹出,起限定插入和删除操作中表的两端进行。

Deque的容量有两张模式,一种是固定长度,另一种是容量有限。同Queue一样,Deque也定义了两套操作访问元素的方法,比如在头部和尾部插入、删除、检索元素,同样的,一种是在满队列或者空队列的操作元素时,会报异常,而一种则会 return null 或者 return false

  • LinkedList 大小可变的链表双端队列,允许元素为null
  • ArrayDeque 大小可变的数组双端队列,不允许 null

LinkedList 和 ArrayDeque 是现场不安全的容器

在并发场景下,推荐使用 LinkedBlockingDeque

  • LinkedBlockingDeque 阻塞的双向列表,在队列为空时,获取操作将会被阻塞,直到有元素添加

JDK1.5中的阻塞队列操作

方法描述极限
add添加一个元素如果队列满了,则抛出一个 IllegalSlabEepeplian 异常
remove移除并返回队列头部元素如果队列为空,则抛出一个 NoSuchElementException 异常
element返回队列头部元素如果队列为空,则抛出一个 NoSuchElementException 异常
offer添加一个元素并返回 true如果队列已满,则返回 false
poll移除并返回队列头部的元素如果队列已空,则返回 null
peek返回队列头部元素如果队列为空,则返回 null
put移除一个元素如果队列满,则阻塞
take移除并返回列头部元素如果队列为空,则阻塞

remove、elemet、offer、poll、peek 是属于 Queue 接口

数组实现:

添加元素

在这里插入图片描述

删除元素

在这里插入图片描述

链表实现

添加元素

在这里插入图片描述

删除元素

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Xiang想`

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值