Java Deque实现及使用方法

一、Deque简介

Java Deque(双端队列)接口是Java集合框架中的一部分,用于在队列的两端插入和删除元素。它是一个线性集合,支持元素的插入、删除和检查操作,可以用作栈和队列的混合体。

Deque接口有两个实现类:LinkedList和ArrayDeque。LinkedList底层是由双向链表实现的,而ArrayDeque底层则是用数组实现的。两者都实现了Deque接口,但是在某些情况下,这些实现可能会产生性能差异。

二、Deque的使用方法

Deque接口有丰富的API,可以满足不同的需求。下面对Deque的使用方法进行介绍。

1. 添加元素

向Deque中添加元素可以用addFirst()、addLast()、offerFirst()和offerLast()四个方法。


Deque<String> deque = new LinkedList<>();
deque.addFirst("first"); //在队列头部添加元素
deque.addLast("last"); //在队列尾部添加元素
deque.offerFirst("offer first"); //在队列头部添加元素
deque.offerLast("offer last"); //在队列尾部添加元素

2. 获取元素

从Deque中获取元素可以使用getFirst()、getLast()、peekFirst()和peekLast()四个方法。


Deque<String> deque = new LinkedList<>();
deque.add("first");
deque.add("second");
deque.add("third");
String first = deque.getFirst(); //获取队列头部的元素,如果队列为空,则返回NoSuchElementException异常。
String last = deque.getLast(); //获取队列尾部的元素,如果队列为空,则返回NoSuchElementException异常。
String peekFirst = deque.peekFirst(); //获取队列头部的元素,如果队列为空,则返回null。
String peekLast = deque.peekLast(); //获取队列尾部的元素,如果队列为空,则返回null。

3. 删除元素

从Deque中删除元素可以使用removeFirst()、removeLast()、pollFirst()和pollLast()四个方法。


Deque<String> deque = new LinkedList<>();
deque.add("first");
deque.add("second");
deque.add("third");
String first = deque.removeFirst(); //删除并返回队列头部的元素,如果队列为空,则返回NoSuchElementException异常。
String last = deque.removeLast(); //删除并返回队列尾部的元素,如果队列为空,则返回NoSuchElementException异常。
String pollFirst = deque.pollFirst(); //删除并返回队列头部的元素,如果队列为空,则返回null。
String pollLast = deque.pollLast(); //删除并返回队列尾部的元素,如果队列为空,则返回null。

4. 检查元素

检查Deque中是否含有某个元素可以用contains()方法,获取Deque中元素的个数可以用size()方法。


Deque<String> deque = new LinkedList<>();
deque.add("first");
deque.add("second");
deque.add("third");
boolean contains = deque.contains("first"); //检查队列中是否含有"first"元素
int size = deque.size(); //获取队列中元素的个数

三、LinkedList与ArrayDeque的性能比较

由于LinkedList和ArrayDeque在底层的实现方式不同,所以它们的性能表现也有所差异。下面通过代码进行对比。

1. LinkedList性能测试


long startTime = System.currentTimeMillis();
Deque<Integer> deque = new LinkedList<>();
for (int i = 0; i < 1000000; i++) {
    deque.addLast(i);
}
while (deque.size() > 0) {
    deque.removeFirst();
}
long endTime = System.currentTimeMillis();
System.out.println("LinkedList time: " + (endTime - startTime) + "ms");

2. ArrayDeque性能测试


long startTime = System.currentTimeMillis();
Deque<Integer> deque = new ArrayDeque<>();
for (int i = 0; i < 10000000; i++) {
    deque.addLast(i);
}
while (deque.size() > 0) {
    deque.removeFirst();
}
long endTime = System.currentTimeMillis();
System.out.println("ArrayDeque time: " + (endTime - startTime) + "ms");

由于性能测试结果会受到环境和代码的影响,所以上面的代码只是为了演示LinkedList和ArrayDeque的性能差异,并不代表实际情况。

至此,我们已经了解了Java Deque接口的实现及使用方法,可以在实际开发中根据需要选择适合的实现类。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/157388.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-18 20:03
下一篇 2024-11-18 20:03

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Python中init方法的作用及使用方法

    Python中的init方法是一个类的构造函数,在创建对象时被调用。在本篇文章中,我们将从多个方面详细讨论init方法的作用,使用方法以及注意点。 一、定义init方法 在Pyth…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • VSCode为什么无法运行Java

    解答:VSCode无法运行Java是因为默认情况下,VSCode并没有集成Java运行环境,需要手动添加Java运行环境或安装相关插件才能实现Java代码的编写、调试和运行。 一、…

    编程 2025-04-29
  • Java任务下发回滚系统的设计与实现

    本文将介绍一个Java任务下发回滚系统的设计与实现。该系统可以用于执行复杂的任务,包括可回滚的任务,及时恢复任务失败前的状态。系统使用Java语言进行开发,可以支持多种类型的任务。…

    编程 2025-04-29

发表回复

登录后才能评论