Deque是一个双端队列接口,继承自Queue接口,Deque的实现类是LinkedList、ArrayDeque、LinkedBlockingDeque,其中LinkedList是最常用的。
关于Queue的介绍可以看上一篇文章:Java队列Queue使用详解
Deque有三种用途:
-
普通队列(一端进另一端出):
Queue queue = new LinkedList()或Deque deque = new LinkedList() -
双端队列(两端都可进出)
Deque deque = new LinkedList() -
堆栈
Deque deque = new LinkedList()
注意:Java堆栈Stack类已经过时,Java官方推荐使用Deque替代Stack使用。Deque堆栈操作方法:push()、pop()、peek()。
Deque是一个线性collection,支持在两端插入和移除元素。名称 deque 是“double ended queue(双端队列)”的缩写,通常读为“deck”。大多数 Deque 实现对于它们能够包含的元素数没有固定限制,但此接口既支持有容量限制的双端队列,也支持没有固定大小限制的双端队列。
此接口定义在双端队列两端访问元素的方法。提供插入、移除和检查元素的方法。每种方法都存在两种形式:一种形式在操作失败时抛出异常,另一种形式返回一个特殊值(null 或 false,具体取决于操作)。插入操作的后一种形式是专为使用有容量限制的 Deque 实现设计的;在大多数实现中,插入操作不能失败。</

本文详细介绍了Java中的双端队列Deque接口及其常用实现类,如LinkedList、ArrayDeque、LinkedBlockingDeque。Deque作为Queue的扩展,支持在两端进行插入和移除操作,适用于普通队列、双端队列和堆栈场景。Java官方推荐使用Deque替代已过时的Stack类。文章还列举了Deque的各种操作方法,并对比了将其作为FIFO队列和LIFO堆栈使用时的方法等价性。
最低0.47元/天 解锁文章
332

被折叠的 条评论
为什么被折叠?



