Java「Deque」 方法详解:从入门到实战

Java Deque 各种方法解析:从入门到实战

在 Java 编程中,Deque(双端队列)是一个功能强大的数据结构,允许开发者从队列的两端高效地添加、删除和检查元素。作为 java.util 包中的一部分,Deque 接口继承自 Queue,并扩展了支持双端操作的能力。无论是实现栈、队列,还是处理复杂的算法问题,Deque 都展现了其灵活性和实用性。

本文将深入解析 Deque 的各种方法,涵盖其分类、用法及示例代码,帮助你在 CSDN 社区中快速掌握这一数据结构,提升代码的专业性与效率。无论你是 Java 初学者还是有经验的开发者,这篇博客都将为你提供全面的学习资源。


什么是 Deque?

DequeDouble Ended Queue 的缩写,意为双端队列。它允许在队列的头部和尾部执行插入、删除和检查操作。Deque 接口定义了一系列方法,使其既可以用作栈(LIFO,后进先出),也可以用作队列(FIFO,先进先出),甚至是更复杂的双端队列。

Java 中 Deque 的常见实现类包括:

  • ArrayDeque:基于数组的双端队列,性能优异,推荐使用。
  • LinkedList:基于双向链表的双端队列,适合特定场景。

接下来,我们将详细解析 Deque 的各种方法,并通过代码示例展示其用法。


Deque 的方法分类与解析

Deque 接口提供了丰富的方法,涵盖添加、删除、检查等操作。为了便于理解,我们将方法分为几类,并逐一讲解。

1. 添加元素的方法

Deque 支持从头部或尾部添加元素,方法分为抛异常和返回布尔值的两类:

  • addFirst(E e):在队列头部添加元素,如果失败(如容量限制)抛出异常。
  • addLast(E e):在队列尾部添加元素,失败时抛出异常。
  • offerFirst(E e):在队列头部添加元素,返回 true 表示成功,false 表示失败。
  • offerLast(E e):在队列尾部添加元素,返回是否成功。

示例代码:

import java.util.Deque;
import java.util.ArrayDeque;public class DequeDemo {public static void main(String[] args) {Deque<String> deque = new ArrayDeque<>();deque.addFirst("A");    // 头部添加 "A"deque.addLast("B");     // 尾部添加 "B"deque.offerFirst("C");  // 头部添加 "C"deque.offerLast("D");   // 尾部添加 "D"System.out.println(deque); // 输出: [C, A, B, D]}
}

说明:
addFirstaddLast 在队列满时抛出 IllegalStateException,而 offerFirstofferLast 更温和,仅返回布尔值,适合需要容错的场景。


2. 删除元素的方法

Deque 支持从两端删除元素,方法同样分为抛异常和返回 null 的两类:

  • removeFirst():移除并返回头部元素,队列为空时抛出 NoSuchElementException
  • removeLast():移除并返回尾部元素,队列为空时抛出异常。
  • pollFirst():移除并返回头部元素,队列为空时返回 null
  • pollLast():移除并返回尾部元素,队列为空时返回 null

示例代码:

import java.util.Deque;
import java.util.ArrayDeque;public class DequeDemo {public static void main(String[] args) {Deque<String> deque = new ArrayDeque<>();deque.add("A");deque.add("B");deque.add("C");String first = deque.removeFirst(); // 移除 "A"String last = deque.removeLast();   // 移除 "C"System.out.println("First: " + first); // First: ASystem.out.println("Last: " + last);   // Last: CSystem.out.println(deque);            // [B]}
}

说明:
removeFirstremoveLast 要求队列非空,否则抛异常;pollFirstpollLast 更安全,适合处理不确定是否为空的情况。


3. 检查元素的方法

检查方法用于查看队列两端的元素,但不移除:

  • getFirst():返回头部元素,队列为空时抛出 NoSuchElementException
  • getLast():返回尾部元素,队列为空时抛出异常。
  • peekFirst():返回头部元素,队列为空时返回 null
  • peekLast():返回尾部元素,队列为空时返回 null

示例代码:

import java.util.Deque;
import java.util.ArrayDeque;public class DequeDemo {public static void main(String[] args) {Deque<String> deque = new ArrayDeque<>();deque.add("A");deque.add("B");deque.add("C");String first = deque.getFirst(); // "A"String last = deque.getLast();   // "C"System.out.println("First: " + first); // First: ASystem.out.println("Last: " + last);   // Last: CSystem.out.println(deque);            // [A, B, C]}
}

说明:
getFirstgetLast 要求队列非空,而 peekFirstpeekLast 返回 null,适合避免异常的场景。


4. 栈相关方法

Deque 可以用作栈,支持 LIFO 操作:

  • push(E e):在头部添加元素(等同于 addFirst)。
  • pop():移除并返回头部元素(等同于 removeFirst)。

示例代码:

import java.util.Deque;
import java.util.ArrayDeque;public class DequeDemo {public static void main(String[] args) {Deque<String> stack = new ArrayDeque<>();stack.push("A");    // 入栈 "A"stack.push("B");    // 入栈 "B"String top = stack.pop(); // 出栈 "B"System.out.println("Top: " + top); // Top: BSystem.out.println(stack);        // [A]}
}

说明:
pushpop 是栈的经典操作,Deque 提供了比传统 Stack 类更高效的实现。


5. 队列相关方法

Deque 也可以用作队列,支持 FIFO 操作:

  • add(E e):在尾部添加元素(等同于 addLast)。
  • remove():移除并返回头部元素(等同于 removeFirst)。

示例代码:

import java.util.Deque;
import java.util.ArrayDeque;public class DequeDemo {public static void main(String[] args) {Deque<String> queue = new ArrayDeque<>();queue.add("A");    // 入队 "A"queue.add("B");    // 入队 "B"String front = queue.remove(); // 出队 "A"System.out.println("Front: " + front); // Front: ASystem.out.println(queue);            // [B]}
}

说明:
这些方法让 Deque 成为标准队列的有效替代品。


6. 其他实用方法

Deque 还提供了一些辅助方法:

  • size():返回队列中元素数量。
  • isEmpty():检查队列是否为空。
  • contains(Object o):检查是否包含某个元素。
  • clear():清空队列。

示例代码:

import java.util.Deque;
import java.util.ArrayDeque;public class DequeDemo {public static void main(String[] args) {Deque<String> deque = new ArrayDeque<>();deque.add("A");deque.add("B");deque.add("C");System.out.println(deque.size());       // 3System.out.println(deque.isEmpty());    // falseSystem.out.println(deque.contains("B")); // truedeque.clear();System.out.println(deque.isEmpty());    // true}
}

说明:
这些方法简单实用,适合日常操作和状态检查。


方法选择时的注意事项

在实际使用中,选择合适的方法至关重要:

  • 异常 vs 返回值add/remove/get 方法在失败时抛异常,适合确保操作成功的场景;offer/poll/peek 返回布尔值或 null,适合容错处理。
  • 空队列处理:操作空队列时,removeget 会抛异常,需提前检查 isEmpty()pollpeek 更安全。
  • 性能考虑ArrayDeque 是大多数场景下的首选,因其基于数组实现,内存效率和操作速度更高。

结语

通过对 Deque 各种方法的详细解析,我们可以看到它在 Java 中的强大功能和灵活性。从添加、删除到检查元素,Deque 提供了丰富的接口,适用于栈、队列等多种数据结构需求。掌握这些方法,不仅能提升代码效率,还能让你的程序更具专业性。

希望这篇博客能帮助你在 CSDN 社区中深入理解 Deque,并在实际项目中灵活运用。欢迎留言讨论你的使用经验或问题,让我们一起进步!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/39442.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

目标检测20年(三)

对这篇论文感兴趣的小伙伴可以订阅笔者《目标检测》专栏&#xff0c;关注笔者对该文献的阅读和理解。 前两篇解读链接&#xff1a; 目标检测20年&#xff08;一&#xff09;-CSDN博客 目标检测20年&#xff08;二&#xff09;-CSDN博客 目录 四、 检测器的加速发展 4.1 特…

LLM之RAG实战(五十二)| 如何使用混合搜索优化RAG 检索

在RAG项目中&#xff0c;大模型生成的参考内容&#xff08;专业术语称为块&#xff09;来自前一步的检索&#xff0c;检索的内容在很大程度上直接决定了生成的效果&#xff0c;因此检索对于RAG项目至关重要&#xff0c;最常用的检索方法是关键字搜索和语义搜索。本文将分别介绍…

2025-3-24 leetcode刷题情况(动态规划——01背包)

一、416.分割等和子集 1.题目描述 给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集&#xff0c;使得两个子集的元素和相等。 2.代码 3.思路 首先进行边界检查&#xff0c;若数组为空则直接返回 false。接着计算数组元素总和&#xff…

Lineageos 22.1(Android 15)实现负一屏

一、前言 方案是参考的这位大佬的&#xff0c;大家可以去付费订阅支持一波。我大概理一下Android15的修改。 大佬的方案代码 二、Android15适配调整 1.bp调整&#xff0c;加入aidl引入&#xff0c;这样make之后就可以索引代码了 filegroup {name: "launcher-src"…

5G NR PRACH 随机接入前导序列

目录 一、前言二、随机接入前导序列的产生三、 N c s N_{cs} Ncs​的规划3.1、 L R A L_{RA} LRA​839 N c s N_{cs} Ncs​规划3.2、 L R A L_{RA} LRA​139 N c s N_{cs} Ncs​规划3.3、 N c s N_{cs} Ncs​确定方法 四、根序列的规划4.1、根序列的选择与确定4.2、循环移位 …

【VUE】day07 路由

【VUE】day07 路由 1. 路由2. 前端路由的工作方式3. 实现简易的前端路由4. 安装和配置路由4.1 安装vue-router包4.2 创建路由模块4.3 导入并挂在路由模块 5. 在路由模块中声明路由的对应关系5.1 router-view 1. 路由 在 Vue.js 中&#xff0c;路由&#xff08;Routing&#xf…

WPS宏开发手册——使用、工程、模块介绍

目录 系列文章前言1、开始1.1、宏编辑器使用步骤1.2、工程1.3、工程 系列文章 使用、工程、模块介绍 JSA语法 第三篇练习练习题&#xff0c;持续更新中… 前言 如果你是开发人员&#xff0c;那么wps宏开发对你来说手拿把切。反之还挺吃力&#xff0c;需要嘻嘻&#xf…

数学概念学习

# 欧式空间 ## 定义 日常生活观察到的几何空间&#xff1a;一维、平面和三维空间。 ## 点与向量 是欧式空间的基本元素。 ## 距离和内积 距离&#xff1a;通过欧几里得距离公式计算 内积&#xff08;点积&#xff09;&#xff1a; 通过两个向量的内积来测量他们的相似性&…

InnoDB 引擎核心知识点

InnoDB 引擎核心知识点 6.1 逻辑存储结构 表空间&#xff08;Tablespace&#xff09;&#xff1a;所有数据逻辑上存储在一个表空间中&#xff0c;物理上可能由多个文件组成。段&#xff08;Segment&#xff09;&#xff1a;分为数据段&#xff08;B树叶子节点&#xff09;、索引…

C++《红黑树》

在之前的篇章当中我们已经了解了基于二叉搜索树的AVL树&#xff0c;那么接下来在本篇当中将继续来学习另一种基于二叉搜索树的树状结构——红黑树&#xff0c;在此和之前学习AVL树类似还是通过先了解红黑树是什么以及红黑树的结构特点&#xff0c;接下来在试着实现红黑树的结构…

java实现coze平台鉴权+工作流调用(踩坑记录)

问题偏多建议大家看完文章后再开始实现 OAuth鉴权 https://www.coze.cn/open/docs/developer_guides/preparation https://www.coze.cn/open/docs/developer_guides/oauth_apps OAuth 授权码鉴权 https://www.coze.cn/open/docs/developer_guides/oauth_code 创建OAuth应…

2025年优化算法:龙卷风优化算法(Tornado optimizer with Coriolis force,TOC)

龙卷风优化算法&#xff08;Tornado optimizer with Coriolis force&#xff09;是发表在中科院二区期刊“ARTIFICIAL INTELLIGENCE REVIEW”&#xff08;IF&#xff1a;11.7&#xff09;的2025年智能优化算法 01.引言 当自然界的狂暴之力&#xff0c;化身数字世界的智慧引擎&…

面试题分享-多线程顺序打印奇偶数

目录 1.题目详情 2.解题思路 2.1.分析题目 2.2.解析思路 3.代码实现 4.运行结果 1.题目详情 昨天刷抖音&#xff0c;遇到一个面试题&#xff0c;描述如下&#xff1a; 请使用两个线程&#xff0c;分别顺序交替打印奇数和偶数&#xff0c;直到10为止。例如有两个线程&#…

QuecPython 网络协议之TCP/UDP协议最祥解析

概述 IP 地址与域名 IP 地址是网络中的主机地址&#xff0c;用于两台网络主机能够互相找到彼此&#xff0c;这也是网络通信能够成功进行的基础。IP 地址一般以点分十进制的字符串来表示&#xff0c;如192.168.1.1。 ​ 我们日常访问的网站&#xff0c;其所在的服务器主机都有…

React - LineChart组件编写(用于查看每日流水图表)

一、简单版本 LineChart.tsx // src/component/LineChart/LineChart.tsx import React, {useEffect,useRef,useImperativeHandle,forwardRef,useMemo,useCallback, } from react; import * as echarts from echarts/core; import type { ComposeOption } from echarts/core; …

医学图像分割数据集肺分割数据labelme格式6299张2类别

数据集格式&#xff1a;labelme格式(不包含mask文件&#xff0c;仅仅包含jpg图片和对应的json文件) 图像分辨率&#xff1a;1024x1024 图片数量(jpg文件个数)&#xff1a;6299 标注数量(json文件个数)&#xff1a;6299 标注类别数&#xff1a;2 标注类别名称:["leftl…

帕金森病致生活艰难,如何缓解心理负担?

你是否留意到身边有人手部不由自主地颤抖&#xff0c;且肢体变得僵硬&#xff0c;行动也愈发迟缓&#xff1f;这很可能是帕金森病的症状。帕金森病是一种常见的神经系统退行性疾病&#xff0c;多发生于中老年人。​ 静止性震颤往往是帕金森病的首发症状&#xff0c;患者在安静状…

从零构建大语言模型全栈开发指南:第二部分:模型架构设计与实现-2.1.1自注意力机制(Scaled Dot-Product Attention)的逐行代码实现

👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 2.1.1 自注意力机制(Scaled Dot-Product Attention)的逐行代码实现1. 自注意力机制的核心原理与数学表达1.1 注意力计算的三元组:`Q, K, V`2. 逐行代码实现与解析2.1 输入嵌入与权重矩阵初始化2.2 完…

机械臂【逆运动学】

回顾正运动学fk&#xff1a; IK&#xff1a; 几何法 代数法 六轴 456轴交再同一点 有解析解 下列公式为正运动学部分结论 a和d是长度 &#xff0c;theta和alfa是角度 **疑问&#xff1a;alfa00&#xff1f; Z轴互相平行 ** 已知末端要在空间XYZ处如下 绿色项&#x…

IDEA批量替换项目下所有文件中的特定内容

文章目录 1. 问题引入2. 批量替换项目下所有文件中的特定内容2.1 右键项目的根目录&#xff0c;点击在文件中替换2.2 输入要替换的内容 3. 解决替换一整行文本后出现空行的问题4. 增加筛选条件提高匹配的精确度 更多 IDEA 的使用技巧可以查看 IDEA 专栏&#xff1a; IDEA 1. 问…