Queue(单项队列)和Deque(双端队列)的知识点整理

本文详细介绍了Java中的Queue和Deque接口及其主要实现类,如ArrayDeque和LinkedList。Queue作为单向队列,遵循FIFO原则,而Deque则支持FIFO和LIFO操作。ArrayDeque在内存占用和效率上通常优于LinkedList,但不支持null元素。Deque额外提供了首尾删除匹配元素的功能。了解这些概念有助于优化Java程序中的数据结构选择。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、Queue(单向队列)

1.1 定义

常见队列就是FIFO(先进先出)队列,可以实现前端删除(peek/pop from front),后端添加(push to back)的功能。

1.2 实现(既可以用数组-顺序队列,也可以用链表-链式队列)

子接口:BlockingQueue
在这里插入图片描述

  1. Java中的单项队列是用链表实现的;
  2. 后面的Deque(双端队列)继承了Queue,是重点,也是一个好东西。
  3. Queue本身是一个接口,继承了Collection集合;
  4. 其中有基本的队列抽象方法,三类,队尾插入元素,队头取出元素,以及删除队头元素;

方法:抛出异常 / 返回默认值(false / null)
添加元素:add / offer
删除:remove / poll
查找:element / peek

在这里插入图片描述

2、Deque(双端队列)

1.1 定义

双端队列,顾名思义,就是不光是FIFO(先进先出),也可以后进先出(LIFO),也有优先级队列。。。

1.2 实现

双端队列(Deque)继承了单向队列(Queue),也继承了其中所有的抽象方法,所以也包括基本队列的增删查方法。
在这里插入图片描述
实现类:LinkedList、ArrayDeque、ConcurrentLinkedDeque、LinkedBlockingDeque
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注意:ArrayDeque(底层是循环数组)和LinkedList(底层是双向循环链表)

  1. 占用内存:数组中只需要存储数据,双向链表还需要存储前一个结点和后一个结点的地址,所以内存消耗较大。
  2. 效率:查询来说,数组天生比链表有优势,对于增删来说,队列只有头部删除,尾部插入操作,ArrayDeque只需要将头部或者尾部变量像前或者向后移动一位,而LinkedList还需要进行指针的连接操作,所以ArrayDeque的效率要比LinkedList高。
  3. 空值:ArrayDeque不允许插入null,LinkedList允许插入null(但是最好不要这么做)。
  4. 安全:两个都是线程不安全的。
    在这里插入图片描述

1.3 方法

Deque额外实现的方法如下:(首尾均可以增删查)
在这里插入图片描述
Deque可以当作Queue使用,即先进先出队列。
在这里插入图片描述
Queue可以当作Stack使用。
在这里插入图片描述
Deque中额外的方法还有一个删除第一次或者最后一次匹配到的元素。

boolean removeFirstOccurrence(Object o);
boolean removeLastOccurrence(Object o);

参考文献:
1、Queue、Deque、LinkedList、ArrayDeque关系及方法
2、深入理解Java集合之—Deque
3、为什么java不推荐使用vector
4、深入浅出分析 ArrayDeque

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值