Java并发基础:Deque接口和Queue接口的区别?

Java并发基础:Deque接口和Queue接口的区别? - 程序员古德

核心概念

Deque(double ended queue,双端队列)和Queue(队列)都是Java集合框架中的接口,它们用于处理元素的排队和出队,但是它们之间存在一些重要的区别,如下:

1、Queue接口

Queue接口代表一个先进先出(FIFO)的队列,只能从一端添加元素,并从另一端移除元素,因此,可以使用add()offer()方法将元素添加到队列的末尾,使用remove()poll()方法从队列的头部移除元素,如果尝试从一个空的队列中移除元素,remove()方法会抛出NoSuchElementException,而poll()方法则会返回null

2、Deque接口

Deque接口,即双端队列,允许从两端添加或者移除元素,它提供了两套添加和移除元素的方法,一套在队列的头部操作,另一套在队列的尾部操作,因此Deque就可以当作队列(FIFO)或者栈(LIFO)来使用,对于Deque,可以在队列头部使用addFirst()offerFirst()添加元素,使用removeFirst()pollFirst()移除元素;在队列尾部使用addLast()offerLast()添加元素,使用removeLast()pollLast()移除元素,如果尝试从一个空的双端队列中移除元素,那么相关的removeXXX()方法同样会抛出NoSuchElementException,而pollXXX()方法会返回null

Queue接口和Deque接口的主要区别在于,Queue接口仅支持在一端添加元素,在另一端移除元素,而Deque接口则支持在两端都进行添加和移除元素的操作,另外,Deque接口的功能更强大,因为它可以当作队列、栈或者双端队列来使用,而Queue接口只能当作队列来使用。

代码案例

Java并发基础:Deque接口和Queue接口的区别? - 程序员古德

Deque

Deque接口代表一个双端队列(double-ended queue),双端队列是一个具有队列和栈的性质的数据结构,它允许元素从两端插入和删除,因此可以在队列的前面(头部)或后面(尾部)添加或移除元素,它的主要功能包括:

1、添加元素:

  1. addFirst(E e) / offerFirst(E e):在队列的头部插入元素,如果队列已满,addFirst会抛出IllegalStateException,而offerFirst则返回false
  2. addLast(E e) / offerLast(E e):在队列的尾部插入元素,如果队列已满,addLast会抛出IllegalStateException,而offerLast则返回false

2、移除元素:

  1. removeFirst() / pollFirst():从队列的头部移除并返回元素,如果队列为空,removeFirst会抛出NoSuchElementException,而pollFirst则返回null
  2. removeLast() / pollLast():从队列的尾部移除并返回元素,如果队列为空,removeLast会抛出NoSuchElementException,而pollLast则返回null

3、检查元素

  1. getFirst() / peekFirst():获取但不移除队列头部的元素,如果队列为空,getFirst会抛出NoSuchElementException,而peekFirst则返回null
  2. getLast() / peekLast():获取但不移除队列尾部的元素,如果队列为空,getLast会抛出NoSuchElementException,而peekLast则返回null

Deque接口的使用场景非常广泛,主要包括如下:

  1. 当需要一个可以作为队列(FIFO)或栈(LIFO)使用的数据结构时。
  2. 在需要高效地在两端添加或移除元素的场景中,如实现撤销/重做功能、缓冲区管理等。
  3. 作为其他数据结构的底层实现,如实现一个自定义的栈或队列。

下面是一个简单的代码示例,展示了如何使用Deque接口,如下代码:

import java.util.Deque;  
import java.util.LinkedList;  public class DequeExample {  public static void main(String[] args) {  Deque<String> deque = new LinkedList<>();  // 在队列头部添加元素  deque.addFirst("Element 1 (Head)");  // 在队列尾部添加元素  deque.addLast("Element 2 (Tail)");  // 在队列头部继续添加元素  deque.offerFirst("Element 0 (Head)");  // 打印队列元素  System.out.println("Deque contents: " + deque);  // 从队列头部移除并返回元素  String removedElement = deque.pollFirst();  System.out.println("Removed element from head: " + removedElement);  // 从队列尾部移除并返回元素  removedElement = deque.pollLast();  System.out.println("Removed element from tail: " + removedElement);  // 检查队列头部元素而不移除  String headElement = deque.peekFirst();  System.out.println("Head element: " + headElement);  // 检查队列是否为空  System.out.println("Deque is empty? " + deque.isEmpty());  }  
}

输出将会是:

Deque contents: [Element 0 (Head), Element 1 (Head), Element 2 (Tail)]  
Removed element from head: Element 0 (Head)  
Removed element from tail: Element 2 (Tail)  
Head element: Element 1 (Head)  
Deque is empty? false

在上面代码中,使用了LinkedList类作为Deque接口的实现,因为LinkedList类实现了Deque接口,因此它提供了双端队列的所有操作,向队列中添加了一些元素,然后从头部和尾部移除它们,并检查了队列的头部元素和是否为空。

Queue

代表一个队列数据结构,即一种特殊的线性表,只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,这种操作规则也被称为“先进先出”(FIFO,First-In-First-Out),它的主要功能包括:

1、插入元素:

  1. add(E e):将指定的元素插入此队列中(如果立即可行且不会违反容量限制),成功时返回 true,如果当前没有可用的空间,则抛出 IllegalStateException,不过,在 Queue 接口的实现中,这个方法通常不会抛出异常,因为大多数队列实现都是有界的,但这个界限通常很大。
  2. offer(E e):将指定的元素插入此队列中(如果立即可行且不会违反容量限制),成功时返回 true,如果当前没有可用的空间,则返回 false

2、移除元素

  1. remove():移除并返回此队列的头部,如果此队列为空,则抛出 NoSuchElementException
  2. poll():移除并返回此队列的头部,或返回 null 如果此队列为空。

3、检查元素

  1. element():检索,但不移除此队列的头部,如果此队列为空,则抛出 NoSuchElementException
  2. peek():检索,但不移除此队列的头部,或返回 null 如果此队列为空。

使用场景

  • 缓冲:当数据需要以有序的方式处理,但又不需要立即处理所有数据时,队列作为缓冲很有用,例如,打印任务队列,网络请求队列等。
  • 生产者-消费者问题:队列经常用于协调多个线程之间的合作,尤其是在生产者-消费者场景中,生产者将产品放入队列,而消费者从队列中取出产品进行消费。
  • 广度优先搜索:在图论中,队列用于实现广度优先搜索(BFS)算法。
  • 事件驱动的系统:队列可以用于存储待处理的事件,例如用户界面事件或系统事件。

代码示例

下面是一个简单的 Queue 接口使用示例,使用了 LinkedList 类作为实现,如下代码:

import java.util.LinkedList;  
import java.util.Queue;  public class QueueExample {  public static void main(String[] args) {  Queue<String> queue = new LinkedList<>();  // 插入元素  queue.offer("Apple");  queue.offer("Banana");  queue.offer("Cherry");  System.out.println("Initial Queue: " + queue);  // 移除元素  String removedElement = queue.poll();  System.out.println("Removed Element: " + removedElement);  System.out.println("Queue after removal: " + queue);  // 检查元素  String headElement = queue.peek();  System.out.println("Head of the Queue: " + headElement);  // 遍历队列  System.out.println("Iterating over the queue:");  for (String fruit : queue) {  System.out.println(fruit);  }  }  
}

输出:

Initial Queue: [Apple, Banana, Cherry]  
Removed Element: Apple  
Queue after removal: [Banana, Cherry]  
Head of the Queue: Banana  
Iterating over the queue:  
Banana  
Cherry

在这个示例中,创建了一个 Queue,使用 offer 方法插入了几个元素,使用 poll 方法移除了队列的头部元素,并使用 peek 方法来查看当前队列的头部元素,最后,使用增强for循环遍历了队列中的所有元素。

关注我,每天学习互联网编程技术 - 程序员古德

END!

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

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

相关文章

HarmonyOS 创建components目录 定义全局自定义组件导出供整个项目使用

之前我的文章 harmonyOS 自定义组件基础演示讲解 我们讲解了 自定义组件的基础用法 但是 我们是写在单个page文件中的 这样 我们跨文件使用就很不友好了 如下图 指向 ets目录下 创建一个目录 按我们 前端开发以往的习惯 这个目录要叫 components 专门放组件集合的地方 然后 按…

《MySQL 简易速速上手小册》第3章:性能优化策略(2024 最新版)

文章目录 3.1 查询优化技巧3.1.1 基础知识3.1.2 重点案例3.1.3 拓展案例 3.2 索引和查询性能3.2.1 基础知识3.2.2 重点案例3.2.3 拓展案例 3.3 优化数据库结构和存储引擎3.3.1 基础知识3.3.2 重点案例3.3.3 拓展案例 3.1 查询优化技巧 让我们来聊聊如何让你的 MySQL 查询跑得像…

3.3-媒资管理之MinIo分布式文件系统上传视频

文章目录 媒资管理5 上传视频5.1 需求分析5.2 断点续传技术5.2.1 什么是断点续传5.2.2 分块与合并测试5.2.3 视频上传流程5.2.4 minio合并文件测试 5.3 接口定义5.4 上传分块开发5.4.1 DAO开发5.4.2 Service开发5.4.2.1 检查文件和分块5.4.2.2 上传分块5.4.2.3 上传分块测试 5.…

高并发对于服务器性能有什么要求?

随着互联网的普及和应用程序的复杂度增加&#xff0c;高并发已经成为许多应用程序必须面对的问题。高并发是指在短时间内有大量用户同时访问应用程序或数据库&#xff0c;对服务器性能提出了更高的要求。本文将探讨高并发对于服务器性能的要求。 一、高并发对服务器硬件的要求…

【Fabric.js】监听画布or元素的点击、选中、移动、添加、删除销毁、变形等各事件

在fabric使用过程中&#xff0c;如果想要玩各种花样&#xff0c;那么fabric的事件监听是一定、必须、肯定要掌握&#xff01;&#xff01;&#xff01; 例子就用vue项目组件里的代码&#xff0c;fabric的使用跟vue、react、angular之类的框架都没任何关系&#xff01; 并且本de…

第205篇| 送给新年12条格言,一些有用的废话

这是2024年一月份flomo和notion 上聚合的系列文章 (01)&#xff1b; 具体方法用的是这个 &#xff1a; 【知识沙虫&#xff0c;一个简单易用的知识体系建模工具】https://mp.weixin.qq.com/s/V2Cdq-1PbMQYvpE4o9NLpQ 首先&#xff0c;方法用下来还是很给力的。输出很快。不过前…

SERVLET过滤器

SERVLET过滤器 全球因特网用户使用不同类型的Web浏览器访问应用服务器上存储的Web应用程序。每个浏览器根据对应的Web浏览器窗口中的设置显示应用程序中的信息。Web应用程序可能会有一些客户机的Web浏览器不支持的HTML标记或功能。这种情况下,应用程序在客户机的Web浏览器中可…

MIMIC-IV官方视图解析 - AKI 肌酐 (kdigo_creatinine、kdigo_stages)

判断AKI我们可以通过肌酐和尿量两个指标来看&#xff0c; 今天我们主要提取肌酐。 kidgo指南的表格 AKI诊断标准&#xff1a;符合以下情况之一者即可被诊断为AKI&#xff1a;①48小时内Scr升高超过26.5μmol/L(0.3mg/dl)&#xff1b;②Scr升高超过基线1.5倍——确认或推测为7…

利用Intersection Observer实现图片懒加载性能优化

ntersection Observer是浏览器所提供的一个 Javascript API&#xff0c;用于异步的检测目标元素以及祖先或者是顶级的文档视窗的交叉状态 这句话的意思就是&#xff1a; 我们可以看的图片当中&#xff0c;绿色的 target element&#xff08;目标元素&#xff09;&#xff0c;…

删除和清空Hive外部表数据

外部表和内部表区别 未被external修饰的是内部表&#xff08;managed table&#xff09;&#xff0c;被external修饰的为外部表&#xff08;external table&#xff09;&#xff1b; 区别&#xff1a; 内部表数据由Hive自身管理&#xff0c;外部表数据由HDFS管理&#xff1b; …

SpringBoot和SpringMVC

目录 一、springboot项目 &#xff08;1&#xff09;创建springboot项目 &#xff08;2&#xff09;目录介绍 &#xff08;3&#xff09;项目启动 &#xff08;4&#xff09;运行一个程序 &#xff08;5&#xff09;通过其他方式创建和运行springboot项目 二、SpringMVC…

高可用 k8s 1.29 一键安装脚本, 丝滑至极

博客原文 文章目录 集群配置配置清单集群规划集群网络规划 环境初始化主机配置 配置高可用ApiServer安装 nginx安装 Keepalived 安装脚本需要魔法的脚本不需要魔法的脚本配置自动补全加入其余节点 验证集群 集群配置 配置清单 OS&#xff1a; ubuntu 20.04kubernetes&#xf…

【Scala】1. 变量和数据类型

1. 变量和数据类型 1.1 for begining —— hello world 新建hello.scala文件&#xff0c;注意object名字与文件名一致。 object hello { def main(args:Array[String]): Unit { println("hello world!") } }运行后打印结果如下&#xff1a; hello world!Pr…

【射影几何13 】梅氏定理和塞瓦定理探讨

梅氏定理和塞瓦定理 目录 一、说明二、梅涅劳斯&#xff08;Menelaus&#xff09;定理三、塞瓦(Giovanni Ceva&#xff09;定理四、塞瓦点的推广4.1 共线定理4.2 三角形外的塞瓦点 一、说明 在射影几何中&#xff0c;梅涅劳斯&#xff08;Menelaus&#xff09;定理和塞瓦定理是…

最大子数组和[中等]

一、题目 给定一个长度为n的环形整数数组nums&#xff0c;返回nums的非空 子数组 的最大可能和 。 环形数组 意味着数组的末端将会与开头相连呈环状。形式上&#xff0c;nums[i]的下一个元素是nums[(i 1) % n]&#xff0c;nums[i]的前一个元素是nums[(i - 1 n) % n]。 子数…

论文封面下划线总是对不齐,这3步你肯定没做!

论文封面 在写论文时&#xff0c;总会遇到论文封面下划线对不齐&#xff0c;学会下面这三招轻松搞定封面。 解决方法 ①选中文字&#xff0c;点击“插入”&#xff0c;选择“表格”&#xff0c;找到“文本转化为表格”。列数为2&#xff0c;文字分割位置选空格&#xff0c;设置…

第21讲:动态内存管理

1.为什么要有动态内存分配 2.malloc和free 3.calloc 4.realloc 5.笔试题 6.总结c/c中程序内存区域划分 1.为什么要有动态内存分配 为了调整申请的空间大小&#xff0c;使程序员可以申请和释放空间&#xff0c;提高程序的灵活性 2.malloc和free 作用&#xff1a;分配一块…

深入了解Redis:选择适用于你的场景的持久化方案

自然语言处理的发展 文章目录 自然语言处理的发展强烈推荐前言&#xff1a;Redis提供了几种主要的持久化方案&#xff1a;RDB快照持久化&#xff1a;工作原理&#xff1a; AOF日志文件持久化&#xff1a;混合持久化&#xff1a; 总结强烈推荐专栏集锦写在最后 强烈推荐 前些天…

相机图像质量研究(7)常见问题总结:光学结构对成像的影响--镜片固化

系列文章目录 相机图像质量研究(1)Camera成像流程介绍 相机图像质量研究(2)ISP专用平台调优介绍 相机图像质量研究(3)图像质量测试介绍 相机图像质量研究(4)常见问题总结&#xff1a;光学结构对成像的影响--焦距 相机图像质量研究(5)常见问题总结&#xff1a;光学结构对成…

戴上HAUWEI WATCH GT 4,解锁龙年新玩法

春节将至&#xff0c;华为WATCH GT 4作为一款颜值和实力并存的手表&#xff0c;能为节日增添了不少趣味和便利。无论你是钟情于龙年表盘或定制属于自己的表盘&#xff0c;还是过年用来抢红包或远程操控手机拍全家福等等&#xff0c;它都能成为你的“玩伴”。接下来&#xff0c;…