Java 中的 Deque 接口


java.util.Deque 接口是 java.util.Queue 接口的子类型,它支持在两端插入和删除元素。

接口声明

public interface Deque<E>
extends Queue<E>

ArrayDeque 类

java.util.ArrayDeque 类提供可调整大小的数组并实现 Deque 接口。以下是关于数组双端队列的重要要点:

  • 数组双端队列没有容量限制,因此它们根据需要增长以支持使用。

  • 它们不是线程安全的;在没有外部同步的情况下。

  • 它们不支持多个线程的并发访问。

  • 数组双端队列中不允许使用空元素。

  • 它们比 Stack 和 LinkedList 更快。

此类及其迭代器实现了 CollectionIterator 接口的所有可选方法。

类声明

以下是 java.util.ArrayDeque 类的声明:

public class ArrayDeque<E>
extends AbstractCollection<E>
implements Deque<E>, Cloneable, Serializable

这里 <E> 表示一个元素,可以是任何类。例如,如果您正在构建一个整数的数组列表,那么您将将其初始化为:

ArrayList<Integer> list = new ArrayList<Integer>();

类构造函数

序号构造函数 & 描述
1ArrayDeque()
此构造函数用于创建一个空数组双端队列,其初始容量足以容纳 16 个元素。
2ArrayDeque(Collection<? extends E> c)
此构造函数用于创建一个包含指定集合中元素的双端队列。
3ArrayDeque(int numElements)
此构造函数用于创建一个空数组双端队列,其初始容量足以容纳指定数量的元素。

示例

import java.util.ArrayDeque;
import java.util.Deque;

public class Tester {
   public static void main(String[] args) {

      // create an empty array deque with an initial capacity
      Deque<Integer> deque = new ArrayDeque<Integer>(5);

      // use add() method to add elements in the deque
      deque.add(20);
      deque.add(30);
      deque.add(20);
      deque.add(30);
      deque.add(15);
      deque.add(22);
      deque.add(11);

      // let us print all the elements available in deque
      for (Integer number : deque) {
         System.out.println("Number = " + number);
      }

      // getFirst() will retrieve element at first position
      int first = deque.getFirst();
      System.out.println("Retrieved Element is = " + first);

      // getLast() will retrieve element at last position
      int last = deque.getLast();
      System.out.println("Retrieved Element is = " + last);
   }
}

输出

Number = 20
Number = 30
Number = 20
Number = 30
Number = 15
Number = 22
Number = 11
Retrieved Element is = 20
Retrieved Element is = 11

更新于: 2020-06-21

377 次浏览

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告