Java Deque基本概念和使用方法

 更新时间:2025年03月05日 11:49:12   作者:飞滕人生TYF  
Deque双端队列是Java Collections Framework的一部分,支持在两端插入和删除操作,它继承自Queue接口,可以作为队列FIFO或栈LIFO使用,本文介绍java Deque基本概念和使用方法,感兴趣的朋友一起看看吧

在 Java 中,Deque(双端队列)是一个支持在两端插入和删除的队列。它是 Java Collections Framework 的一部分,通过接口和实现类提供了高效的双端操作能力。

Deque 基础概念

  • Deque双端队列,支持在队列的 头部尾部 添加、删除、访问元素。
  • 它继承自 Queue 接口,是一种更加通用的数据结构。
  • 既可以用作 队列(FIFO),也可以用作 栈(LIFO)

接口定义

Deque 是一个接口,常用实现类有:

  • ArrayDeque:基于动态数组的双端队列实现。
  • LinkedList:基于双向链表的双端队列实现。

常见操作分类

  • 头部操作addFirstremoveFirstgetFirst
  • 尾部操作addLastremoveLastgetLast
  • ​​​​​​​通用队列操作offerpollpeek

Deque 的方法详解

1. 添加元素

在头部添加

  • void addFirst(E e):在队列头部插入元素,若队列满则抛出异常。
  • boolean offerFirst(E e):在队列头部插入元素,若队列满返回 false

在尾部添加

  • void addLast(E e):在队列尾部插入元素,若队列满则抛出异常。
  • boolean offerLast(E e):在队列尾部插入元素,若队列满返回 false

示例:

Deque<Integer> deque = new ArrayDeque<>();
deque.addFirst(1); // 在头部添加
deque.addLast(2);  // 在尾部添加
System.out.println(deque); // 输出:[1, 2]

2. 删除元素

从头部删除

  • E removeFirst():删除并返回头部元素,若队列为空则抛出异常。
  • E pollFirst():删除并返回头部元素,若队列为空返回 null

从尾部删除

  • E removeLast():删除并返回尾部元素,若队列为空则抛出异常。
  • E pollLast():删除并返回尾部元素,若队列为空返回 null

示例:

Deque<Integer> deque = new ArrayDeque<>();
deque.addFirst(1);
deque.addLast(2);
deque.removeFirst(); // 删除头部元素
deque.removeLast();  // 删除尾部元素
System.out.println(deque); // 输出:[]

3. 访问元素

访问头部元素

  • E getFirst():获取但不删除头部元素,若队列为空则抛出异常。
  • E peekFirst():获取但不删除头部元素,若队列为空返回 null

访问尾部元素

  • E getLast():获取但不删除尾部元素,若队列为空则抛出异常。
  • E peekLast():获取但不删除尾部元素,若队列为空返回 null。 示例:
Deque<Integer> deque = new ArrayDeque<>();
deque.addFirst(1);
deque.addLast(2);
System.out.println(deque.getFirst()); // 输出:1
System.out.println(deque.getLast());  // 输出:2

4. 栈操作(LIFO)

  • void push(E e):将元素压入栈顶(相当于 addFirst)。
  • E pop():移除并返回栈顶元素(相当于 removeFirst)。

示例:

Deque<Integer> stack = new ArrayDeque<>();
stack.push(1); // 压入栈顶
stack.push(2);
System.out.println(stack.pop()); // 弹出栈顶元素,输出:2
System.out.println(stack.pop()); // 输出:1

5. 队列操作(FIFO)

  • boolean offer(E e):将元素添加到队列尾部(相当于 offerLast)。
  • E poll():移除并返回队列头部元素(相当于 pollFirst)。
  • E peek():获取但不删除队列头部元素(相当于 peekFirst)。

示例:

Deque<Integer> queue = new ArrayDeque<>();
queue.offer(1); // 添加到尾部
queue.offer(2);
System.out.println(queue.poll()); // 移除头部元素,输出:1
System.out.println(queue.peek()); // 获取头部元素,输出:2

6. 删除所有元素

  • void clear():清空队列。

示例:

Deque<Integer> deque = new ArrayDeque<>();
deque.add(1);
deque.add(2);
deque.clear(); // 清空队列
System.out.println(deque.isEmpty()); // 输出:true

7. 检查队列状态

  • boolean isEmpty():检查队列是否为空。
  • int size():返回队列中元素的数量。

Deque 的实现类

1. ArrayDeque

  • 基于动态数组实现。
  • 特点
    • 适合用作栈和队列。
    • 线程不安全,但效率较高。
    • 不允许存储 null 元素。

示例:

Deque<Integer> deque = new ArrayDeque<>();
deque.addFirst(1);
deque.addLast(2);
System.out.println(deque); // 输出:[1, 2]

2. LinkedList

  • 基于双向链表实现。
  • 特点
    • 支持队列和栈操作。
    • 允许存储 null 元素。
    • 适合频繁插入和删除操作的场景。

示例:

Deque<Integer> deque = new LinkedList<>();
deque.addFirst(1);
deque.addLast(2);
System.out.println(deque); // 输出:[1, 2]

常见应用场景

1. 栈实现(LIFO 模式)

Deque 提供了 pushpop 方法,可以方便地模拟栈。

示例:

Deque<Integer> stack = new ArrayDeque<>();
stack.push(1);
stack.push(2);
System.out.println(stack.pop()); // 输出:2
System.out.println(stack.pop()); // 输出:1

2. 队列实现(FIFO 模式)

Deque 提供了 offerpoll 方法,可以模拟队列操作。

示例:

Deque<Integer> queue = new ArrayDeque<>();
queue.offer(1);
queue.offer(2);
System.out.println(queue.poll()); // 输出:1
System.out.println(queue.poll()); // 输出:2

3. 滑动窗口

Deque 可以用作维护滑动窗口的数据结构,例如最大值或最小值的计算。

4. 双端处理

Deque 支持从两端同时处理数据,例如支持同时从头尾访问元素的算法(如回文检查)。

总结

方法分类常用方法描述
添加元素addFirstaddLastoffer向头部或尾部添加元素
删除元素removeFirstremoveLast从头部或尾部删除元素
访问元素getFirstgetLastpeek获取头部或尾部元素,但不删除
栈操作pushpop用作栈的 LIFO 操作
队列操作offerpollpeek用作队列的 FIFO 操作
清空队列clear删除所有元素

推荐使用场景

  • 对于简单的栈或队列操作,使用 ArrayDeque
  • 对于需要频繁插入、删除或允许存储 null 的场景,选择 LinkedList

Deque 是一个功能强大的双端数据结构,在队列和栈操作中非常灵活。根据实际需求选择实现类即可。

到此这篇关于java Deque 详解的文章就介绍到这了,更多相关java Deque 详解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java实现图片文字识别ocr

    java实现图片文字识别ocr

    这篇文章主要介绍了java实现图片文字识别ocr ,非常具有实用价值,需要的朋友可以参考下
    2017-08-08
  • Java性能的十一个用法分享

    Java性能的十一个用法分享

    这篇文章主要介绍了Java性能的十一个用法,需要的朋友可以参考下
    2014-10-10
  • SpringBoot自定义注解如何解决公共字段填充问题

    SpringBoot自定义注解如何解决公共字段填充问题

    本文介绍了在系统开发中,如何使用AOP切面编程实现公共字段自动填充的功能,从而简化代码,通过自定义注解和切面类,可以统一处理创建时间和修改时间,以及创建人和修改人的赋值操作
    2025-03-03
  • jmeter正则表达式的使用

    jmeter正则表达式的使用

    在jmeter中,可以利用正则表达式提取器来帮助我们完成这一动作,本文就详细的介绍一下应该如何使用,感兴趣的可以了解一下
    2021-11-11
  • SpringBoot3集成Quartz的示例代码

    SpringBoot3集成Quartz的示例代码

    Quartz由Java编写的功能丰富的开源作业调度框架,可以集成到几乎任何Java应用程序中,并且能够创建多个作业调度,在实际的业务中,有很多场景依赖定时任务,比如常见的:订单超时处理,业务识别和预警通知等,本文介绍了SpringBoot3如何集成Quartz
    2023-08-08
  • 解决mybatis-plus动态数据源切换不生效的问题

    解决mybatis-plus动态数据源切换不生效的问题

    本文主要介绍了解决mybatis-plus动态数据源切换不生效的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • java 对称二叉树的判断

    java 对称二叉树的判断

    这篇文章主要介绍了java 对称二叉树的判断,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • Kibana的安装和配置全过程

    Kibana的安装和配置全过程

    Kibana是一个开源的数据分析和可视化平台,它与Elasticsearch紧密集成,提供了一个直观的Web界面,使您可以快速地搜索、分析和可视化数据,在本文中,我们将介绍如何安装和配置Kibana
    2024-12-12
  • 如何通过Java添加水印到Word文档

    如何通过Java添加水印到Word文档

    这篇文章主要介绍了如何通过Java添加水印到Word文档,水印是一种常用于各种文档的声明、防伪手段,一般可设置文字水印或者加载图片作为水印。以下内容将分享通过Java编程给Word文档添加水印效果的方法,需要的朋友可以参考下
    2019-07-07
  • Java中ArrayList类的用法与源码完全解析

    Java中ArrayList类的用法与源码完全解析

    这篇文章主要介绍了Java中ArrayList类的用法与源码完全解析,ArrayList类通过List接口实现,是Java中引申出的一种数据结构,需要的朋友可以参考下
    2016-05-05

最新评论