Java 教程
- Java - 首页
- Java - 概述
- Java - 历史
- Java - 特性
- Java 与 C++
- JVM - Java 虚拟机
- Java - JDK 与 JRE 与 JVM
- Java - Hello World 程序
- Java - 环境搭建
- Java - 基本语法
- Java - 变量类型
- Java - 数据类型
- Java - 类型转换
- Java - Unicode 系统
- Java - 基本运算符
- Java - 注释
- Java - 用户输入
- Java - 日期与时间
Java 控制语句
- Java - 循环控制
- Java - 决策制定
- Java - If-else
- Java - Switch
- Java - For 循环
- Java - For-Each 循环
- Java - While 循环
- Java - do-while 循环
- Java - Break
- Java - Continue
面向对象编程
- Java - OOPs 概念
- Java - 对象与类
- Java - 类属性
- Java - 类方法
- Java - 方法
- Java - 变量作用域
- Java - 构造方法
- Java - 访问修饰符
- Java - 继承
- Java - 聚合
- Java - 多态
- Java - 重写
- Java - 方法重载
- Java - 动态绑定
- Java - 静态绑定
- Java - 实例初始化块
- Java - 抽象
- Java - 封装
- Java - 接口
- Java - 包
- Java - 内部类
- Java - 静态类
- Java - 匿名类
- Java - 单例类
- Java - 包装类
- Java - 枚举
- Java - 枚举构造方法
- Java - 枚举字符串
Java 内置类
Java 文件处理
Java 错误与异常
- Java - 异常
- Java - try-catch 块
- Java - try-with-resources
- Java - 多重捕获块
- Java - 嵌套 try 块
- Java - Finally 块
- Java - throw 异常
- Java - 异常传播
- Java - 内置异常
- Java - 自定义异常
Java 多线程
- Java - 多线程
- Java - 线程生命周期
- Java - 创建线程
- Java - 启动线程
- Java - 线程连接
- Java - 线程命名
- Java - 线程调度器
- Java - 线程池
- Java - 主线程
- Java - 线程优先级
- Java - 守护线程
- Java - 线程组
- Java - 关闭钩子
Java 同步
Java 网络
- Java - 网络
- Java - 套接字编程
- Java - URL 处理
- Java - URL 类
- Java - URLConnection 类
- Java - HttpURLConnection 类
- Java - Socket 类
- Java - 泛型
Java 集合
Java 接口
Java 数据结构
Java 集合算法
高级 Java
- Java - 命令行参数
- Java - Lambda 表达式
- Java - 发送邮件
- Java - Applet 基础
- Java - Javadoc 注释
- Java - 自动装箱和拆箱
- Java - 文件不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 文件
- Java - 私有接口方法
- Java - 内部类菱形运算符
- Java - 多分辨率图像 API
- Java - 集合工厂方法
- Java - 模块系统
- Java - Nashorn JavaScript
- Java - Optional 类
- Java - 方法引用
- Java - 函数式接口
- Java - 默认方法
- Java - Base64 编码解码
- Java - Switch 表达式
- Java - Teeing 收集器
- Java - 微基准测试
- Java - 文本块
- Java - 动态 CDS 归档
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指针异常
- Java - 打包工具
- Java - 密封类
- Java - 记录类
- Java - 隐藏类
- Java - 模式匹配
- Java - 简洁数字格式化
- Java - 垃圾回收
- Java - JIT 编译器
Java 杂项
- Java - 递归
- Java - 正则表达式
- Java - 序列化
- Java - 字符串
- Java - 进程 API 改进
- Java - 流 API 改进
- Java - 增强的 @Deprecated 注解
- Java - CompletableFuture API 改进
- Java - 流
- Java - 日期时间 API
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java API 与框架
Java 类参考
- Java - Scanner
- Java - 数组
- Java - 字符串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用资源
Java - Deque 接口
Deque 接口在 java.util 包中提供,它扩展了 Queue 接口。它是一个线性集合,支持在两端插入和删除元素。此接口定义了访问双端队列两端元素的方法。提供了插入、删除和检查元素的方法。
声明
public interface Deque<E> extends Queue<E>
Deque 方法
以下是 Deque 接口的所有实现类都实现的重要双端队列方法列表 -
序号 | 方法及描述 |
---|---|
1 | boolean add(E e)
此方法将指定的元素插入到由该双端队列表示的队列中(换句话说,在该双端队列的尾部),如果可以立即这样做而不违反容量限制,则返回 true,如果当前没有可用空间,则抛出 IllegalStateException。 |
2 | boolean addAll(Collection<? extends E> c)
此方法将指定集合中的所有元素添加到该双端队列的末尾,就像对每个元素调用 addLast(E) 一样,按照集合的迭代器返回的顺序。 |
3 | void addFirst(E e)
此方法将指定的元素插入到该双端队列的前面,如果可以立即这样做而不违反容量限制,则抛出 IllegalStateException 如果当前没有可用空间。 |
4 | void addLast(E e)
此方法将指定的元素插入到该双端队列的末尾,如果可以立即这样做而不违反容量限制,则抛出 IllegalStateException 如果当前没有可用空间。 |
5 | boolean contains(Object o)
此方法如果该双端队列包含指定的元素,则返回 true。 |
6 | Iterator<E> descendingIterator()
此方法返回一个迭代器,该迭代器按反向顺序遍历此双端队列中的元素。 |
7 | E element()
此方法检索但不删除由该双端队列表示的队列的头(换句话说,该双端队列的第一个元素)。 |
8 | E getFirst()
此方法检索但不删除该双端队列的第一个元素。 |
9 | E getLast()
此方法检索但不删除该双端队列的最后一个元素。 |
10 | Iterator<E> iterator()
此方法返回一个迭代器,该迭代器按正确的顺序遍历此双端队列中的元素。 |
11 | boolean offer(E e)
此方法将指定的元素插入到由该双端队列表示的队列中(换句话说,在该双端队列的尾部),如果可以立即这样做而不违反容量限制,则返回 true,如果当前没有可用空间,则返回 false。 |
12 | boolean offerFirst(E e)
此方法将指定的元素插入到该双端队列的前面,除非这会违反容量限制。 |
13 | boolean offerLast(E e)
此方法将指定的元素插入到该双端队列的末尾,除非这会违反容量限制。 |
14 | E peek()
此方法检索但不移除此双端队列表示的队列的头(换句话说,此双端队列的第一个元素),如果此双端队列为空则返回 null。 |
15 | E peekFirst()
此方法检索但不移除此双端队列的第一个元素,如果此双端队列为空则返回 null。 |
16 | E peekLast()
此方法检索但不移除此双端队列的最后一个元素,如果此双端队列为空则返回 null。 |
17 | E poll()
此方法检索并移除此双端队列表示的队列的头(换句话说,此双端队列的第一个元素),如果此双端队列为空则返回 null。 |
18 | E pollFirst()
此方法检索并移除此双端队列的第一个元素,如果此双端队列为空则返回 null。 |
19 | E pollLast()
此方法检索并移除此双端队列的最后一个元素,如果此双端队列为空则返回 null。 |
20 | E pop()
此方法从此双端队列表示的栈中弹出元素。 |
21 | void push(E e)
此方法将元素压入此双端队列表示的栈(换句话说,在该双端队列的头部),如果可以立即执行而不会违反容量限制,则抛出 IllegalStateException 如果当前没有可用空间。 |
22 | E remove()
此方法检索并移除此双端队列表示的队列的头(换句话说,此双端队列的第一个元素)。 |
23 | E removeFirst()
此方法检索并移除此双端队列的第一个元素。 |
24 | boolean removeFirstOccurrence(Object o)
此方法从此双端队列中移除指定元素的第一次出现。 |
25 | E removeLast()
此方法检索并移除此双端队列的最后一个元素。 |
26 | boolean removeLastOccurrence(Object o)
此方法从此双端队列中移除指定元素的最后一次出现。 |
27 | int size()
此方法返回此双端队列中的元素数量。 |
继承的方法
此接口继承自以下接口:
- java.util.Queue
- java.util.Collection
- java.lang.Iterable
示例
在此示例中,我们使用 Deque 实例来演示双端队列的添加、查看和大小操作。
package com.tutorialspoint; import java.util.ArrayDeque; import java.util.Deque; public class DequeDemo { public static void main(String[] args) { Deque<Integer> q = new ArrayDeque<>(); q.add(6); q.add(1); q.add(8); q.add(4); q.add(7); System.out.println("The deque is: " + q); int num1 = q.remove(); System.out.println("The element deleted from the head is: " + num1); System.out.println("The deque after deletion is: " + q); int head = q.peek(); System.out.println("The head of the deque is: " + head); int size = q.size(); System.out.println("The size of the deque is: " + size); } }
输出
The deque is: [6, 1, 8, 4, 7] The element deleted from the head is: 6 The deque after deletion is: [1, 8, 4, 7] The head of the deque is: 1 The size of the deque is: 4