java队列(Queue&Deque)原理

本文详细介绍了Java中的Queue接口及其实现,包括CheckedQueue、AbstractQueue、AsLIFOQueue和PriorityQueue,特别是PriorityQueue的二叉堆实现。此外,还探讨了Deque接口和ArrayDeque的使用,作为Queue和Stack的替代选择。最后提到了Collections类中的队列操作。
摘要由CSDN通过智能技术生成

概述

List,Map 已经讲解完毕,下面主要看一下Queue、Deque的实现原理以及使用方法;
队列与栈是相对的一种数据结构。只允许在一端进行插入操作,而在另一端进行删除操作的线性表。栈的特点是后进先出,而队列的特点是先进先出。
队列的用处很大,但大多都是在其他的数据结构中,比如,树的按层遍历,图的广度优先搜索等都需要使用队列做为辅助数据结构。

Queue

1、Queue(单向队列)概述

Queue类图

从类结构图中可以看到Queue也是继承Collection,所以会有Collection的一些特性和方法;之外Queue还有自己的一些插入、获取和查找方法,这些方法都有两个版本:当操作失败的时候,一个版本会抛出异常,一个版本会返回对应的默认值(null或者false);插入操作的返回默认值形式是专门为有容量限制的队列实现而设计的; 在大多数实现中,插入操作不会失败。

2、CheckedQueue

Collections的一个内部类,用来封装Queue的视图,保证Queue的元素的正确性,主要是通过构造函数来确定,比如:

CheckedQueue(Queue<E> queue, Class<E> elementType) {
    super(queue, elementType);
    this.queue = queue;
}
3、AbstractQueue

对Queue的一些默认实现,比如add()、remove()、element()、clear()、addAll();

4、AsLIFOQueue

封装一个Deque的视图,用来作为LIFO的Queue,Collections的asLifoQueue(Deque)

5、PriorityQueue

PriorityQueue中的元素可以默认自然排序或者通过提供的Comparator(比较器)在队列实例化时指定的排序方式进行排序。PriorityQueue主要通过二叉堆来进行实现,有些时候就把二叉堆叫做优先队列,下面具体讲解一下二叉堆。
二叉堆也是一种二叉树,和查找二叉树不同的是,二叉堆根据是根为最大值还是最小值,分为最小堆和最大堆。

PriorityQueue

PriorityQueue中的元素可以默认自然排序或者通过提供的Comparator(比较器)在队列实例化时指定的排序方式进行排序。PriorityQueue主要通过堆来进行实现,有些时候就把堆叫做优先队列,下面具体讲解一下堆。

1、定义

堆(heap

### 回答1: Java中的队列queue)和双端队列deque)都是常用的数据结构,用于存储一系列元素并进行操作。它们在不同的场景下有不同的用途。 当我们需要在队列尾部插入元素,并从队列头部取出元素时,使用队列queue)是最好的选择。队列queue)遵循先进先出(FIFO)的原则,保证插入的元素排在最后,而取出元素时从队列头部开始。在该场景下对于Java Queue接口的实现类LinkedList即可满足需求。 而在需要在队列头部和尾部同时插入删除元素时,我们可以选择双端队列deque)。双端队列deque)支持在队列头部和尾部两端插入和删除元素,并且可以使用队列和栈两种方式进行操作。JavaDeque接口即为双端队列的接口,常见实现有ArrayDeque和LinkedList。ArrayDeque由于是基于循环数组的实现,因此相比LinkedList在插入删除操作时更加高效。 因此,根据具体的需求和场景选择合适的队列或双端队列实现即可。如果只需要普通的队列功能,则使用Queue或LinkedList即可;需要更多的操作则可使用Deque或ArrayDeque。 ### 回答2: Java中的队列是一种用于存储元素的数据结构,其中存储的元素可以按照先进先出(FIFO)的顺序进行排列。Queue接口是Java集合框架中的一个接口,用于表示队列,可以实现队列的操作,如添加元素、删除元素、检索元素等。 Queue接口继承了Collection接口,该接口提供了添加元素、删除元素、以及检索队列中的元素的方法。Java中的Queue接口有两个主要的实现类,即LinkedList和PriorityQueue。LinkedList实现Queue接口,是Java中最常见的队列类,而PriorityQueue实现Queue和Comparable接口,可以用于创建优先队列。 另一个Java中的队列实现类是Deque(Double Ended Queue)接口。与Queue接口不同的是,Deque接口允许在队列的两端添加或删除元素,因此它支持FIFO和LIFO(后进先出)两种模式。 总之,当我们需要实现一个简单的队列时,可以考虑使用Queue接口,如果需要队列可以在两端添加或删除元素,则可以使用Deque接口。但具体使用哪个接口,还需要根据具体情况具体分析。 ### 回答3: Java队列可以使用QueueDeque两种数据结构来表示,选择使用哪种数据结构主要根据具体的业务需求和设计目的而定。 Queue是一种“先进先出”(FIFO)的队列结构,它表示一组元素的集合,其中新元素被添加到队列的尾部,而元素被提取时从队列的头部开始。Queue接口包括了add,offer,remove,poll,peek等方法。 Deque是一种“双向队列”,它实现Queue接口并提供了高效的插入和删除操作。Deque允许在队列的两端添加或删除元素,可以被用作栈和队列双重行的结构。Deque接口包括了addFirst,addLast,offerFirst,offerLast,removeFirst,removeLast,pollFirst,pollLast,peekFirst,peekLast等方法。 如果只需要实现简单的先进先出队列的功能,使用Queue就足够了,而如果需要在队列两端进行高效的插入和删除操作,建议使用Deque。 总之,根据具体的业务需求和设计目的来选择使用Queue还是Deque
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值