java之双端队列Deque

Deque

1.Queue队列,只能一头进,一头出,在队尾添加,在队首获取。
2.Deque为双端队列,可以在队尾添加和获取,也可以在队首添加和获取。
3.Deque可以用作LIFO(后进先出)堆栈,应优先使用此接口而不是遗留Stack类。在将双端队列用作堆栈时,元素被推入双端队列的开头并从双端队列开头弹出。
等价方法:

堆栈方法Deque方法
push(e)addFirst(e)
pop()removeFirst()
peek()peekFirst()

4.java官方不推荐使用旧的Stack

Deque的实现

Deque接口在Collections API中有 以下两种实现:

  • java.util.LinkedList
  • java.util.ArrayDeque

LinkedList是非常标准的Deque和Queue的实现,其在内部使用链接列表来建模deque或queue。
ArrayDeque类内部存储元素是数组,如果元素数超过数组中的空间,则分配一个新的数组,并移动所有元素,换句话说,ArrayDeque根据需要增长,即 使它将元素存储在数组中。

为什么用Deque不用Stack?

因为Stack是继承Vector,Vector是由数组实现线程安全(方法使用synchronized修饰)的集合类,它包含了大量集合处理的方法,而Stack复用了Vector的方法实现进栈和出栈的操作,基于数组实现相比于链表实现,效率上受影响。同时,因为继承Vector类,Stack可以复用Vector的方法,这是Stack设计不严谨的地方。

ArrayDeque和LinkedList

ArrayDeque是Deque接口的一种具体实现,是依赖于可变数组来实现的。ArrayDeque 没有容量限制,可根据需求自动进行扩容。ArrayDeque可以作为栈来使用,效率要高于 Stack。ArrayDeque也可以作为队列来使用,效率相较于基于双向链表的LinkedList也要更好一些。注意:ArrayDeque不支持为null的元素。
LinkedList与ArrayList一样实现List接口,只是ArrayList是List接口的大小可变数组的实现,LinkedList是List 接口链表的实现。基于链表实现的方式使得 LinkedList 在插入和删除时更优于ArrayList,而随机访问则比ArrayList逊色些。

LinkedList实现所有可选的列表操作,并允许所有的元素包括null。除了实现List接口外,LinkedList类还为在列表的开头及结尾 get、remove 和 insert 元素提供了统一的命名方法。这些操作允许将链接列表用作堆栈、队列或双端队列。

此类实现 Deque 接口,为 add、poll 提供先进先出队列操作,以及其他堆栈和双端队列操作。

所有操作都是按照双重链接列表的需要执行的。在列表中编索引的操作将从开头或结尾遍历列表(从靠近指定索引的一端)。同时,与 ArrayList 一样此实现不是同步的。

当使用队列功能时建议使用LinkedList
当使用栈功能时建议使用ArrayDeque

ArrayDeque源码注释中有一句话:
This class is likely to be faster than {@link Stack} when used as a stack,
and faster than {@link LinkedList} when used as a queue.

ArrayDeque用作栈时比Stack快,用作队列的时候似乎也会比LinkedList快!
所以,ArrayDeque会略胜一筹。

方法及详情可见api文档:
https://www.apiref.com/java11-zh/java.base/java/util/Deque.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值