ArrayDeque双端队列完全解析

ArrayDeque是通过循环数组实现的双端队列,避免内存浪费。利用头尾(head, tail)标记判断是否已满,通过(tail = (tail + 1) & (elements.length - 1)) == head公式,要求数组长度为2的n次方。它可以实现FIFO(先进先出)和LIFO(先进后出)功能,提供addFirst/Last和pollFirst/Last等方法。在操作中,某些情况会抛出异常,有些则返回null。" 51848814,5647356,深入理解Laravel路由机制,"['PHP', 'laravel', 'web开发', '路由机制', '控制器']
摘要由CSDN通过智能技术生成

ArrayDeque双端队列完全解析

重点:

  • 底层通过循环数组实现 俩个重要属性 head tail
  • 不能添加null值,不然会报空指针
  • 每次扩容都是2的n次方
  • 可以实现普通队列先进先出排序,也可以实现栈先进后出的排序
  • 特别留意,它里面通过二进制方式判断数组是否已满
    (tail = (tail + 1) & (elements.length - 1)) == head
  • 注意操作插入和移除时,有Throws exception 和 return Special value 俩种情况

循环数组概念

我们知道,ArrayDeque是通过数组实现队列功能 的;而且具有对数组头尾双端添加和移除对象的功能,但如果数组不能实现循环功能,会出现以下情况

图一

图一

在构建一个ArrayDeque对象时,会初始化head和tail的值为0.当有对象加入数组时,tail的值加1,当有对象出列时,head的值会加1.
而head值 == tail值 ,可以帮我们判断数组是已经满。

如果数组容量固定的情况下,从尾追加数据,从头出列数据,会出现实际数组有空的单元,但却tail会超过数组容量的情况,这种现象称为“假溢出” ;但往往,不可能是一种容量固定的数组,一般会有实现自动扩容的方法,但即便可以扩容,按照上面的逻辑,数组容量不断扩大,tail值一直向后,但从头出列的数据越来起多,前面空的内存单造成的浪费更是不能忽略了。

再往下想,不是说Deque接口实现了头和尾添加和删除数据的功能吗?那它不是可以从头添加数据,不就可以利用到前面已经出列的空的单元吗?
但如果就是单纯的就是在往后追加数据呢?那前面空出的内存单元,就这样舍弃掉?简直“暴殄天物”。

所以,为了解决数组单元浪费的问题,就产生了循环数组。且看图
图二

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值