Java队列 Deque

转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/120828826
本文出自【赵彦军的博客】

Java队列 Queue
Java队列 Deque
Java队列 PriorityQueue
Java栈 Stack
Java阻塞队列 LinkedBlockingDeque

文章目录

Deque

我们知道,Queue 是队列,只能一头进,另一头出。

如果把条件放松一下,允许两头都进,两头都出,这种队列叫双端队列(Double Ended Queue),学名Deque

Java集合提供了接口Deque来实现一个双端队列,它的功能是:

  • 既可以添加到队尾,也可以添加到队首;
  • 既可以从队首获取,又可以从队尾获取。

我们来比较一下QueueDeque出队和入队的方法:

QueueDeque
添加元素到队尾add(E e) / offer(E e)addLast(E e) / offerLast(E e)
取队首元素并删除E remove() / E poll()E removeFirst() / E pollFirst()
取队首元素但不删除E element() / E peek()E getFirst() / E peekFirst()
添加元素到队首addFirst(E e) / offerFirst(E e)
取队尾元素并删除E removeLast() / E pollLast()
取队尾元素但不删除E getLast() / E peekLast()

对于添加元素到队尾的操作,Queue提供了add()/offer()方法,而Deque提供了addLast()/offerLast()方法。添加元素到对首、取队尾元素的操作在Queue中不存在,在Deque中由addFirst()/removeLast()等方法提供。

注意到Deque接口实际上扩展自Queue

public interface Deque<E> extends Queue<E> {
    ...
}

因此,Queue提供的add()/offer()方法在Deque中也可以使用,但是,使用Deque,最好不要调用offer(),而是调用offerLast()

public class Main {
    public static void main(String[] args) {
        Deque<String> deque = new LinkedList<>();
        deque.offerLast("A"); // A
        deque.offerLast("B"); // A <- B
        deque.offerFirst("C"); // C <- A <- B
        System.out.println(deque.pollFirst()); // C, 剩下A <- B
        System.out.println(deque.pollLast()); // B, 剩下A
        System.out.println(deque.pollFirst()); // A
        System.out.println(deque.pollFirst()); // null
    }
}

如果直接写deque.offer(),我们就需要思考,offer()实际上是offerLast(),我们明确地写上offerLast(),不需要思考就能一眼看出这是添加到队尾。

因此,使用Deque,推荐总是明确调用offerLast()/offerFirst()或者pollFirst()/pollLast()方法。

Deque是一个接口,它的实现类有ArrayDequeLinkedList

我们发现LinkedList真是一个全能选手,它即是List,又是Queue,还是Deque。但是我们在使用的时候,总是用特定的接口来引用它,这是因为持有接口说明代码的抽象层次更高,而且接口本身定义的方法代表了特定的用途。

// 不推荐的写法:
LinkedList<String> d1 = new LinkedList<>();
d1.offerLast("z");
// 推荐的写法:
Deque<String> d2 = new LinkedList<>();
d2.offerLast("z");

可见面向抽象编程的一个原则就是:尽量持有接口,而不是具体的实现类。

小结

Deque实现了一个双端队列(Double Ended Queue),它可以:

  • 将元素添加到队尾或队首:addLast()/offerLast()/addFirst()/offerFirst()
  • 从队首/队尾获取元素并删除:removeFirst()/pollFirst()/removeLast()/pollLast()
  • 从队首/队尾获取元素但不删除:getFirst()/peekFirst()/getLast()/peekLast()
  • 总是调用xxxFirst()/xxxLast()以便与Queue的方法区分开;

避免把null添加到队列。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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、付费专栏及课程。

余额充值