📅  最后修改于: 2023-12-03 15:01:58.518000             🧑  作者: Mango
ArrayDeque是Java中的一个双端队列,它实现了Dequeue接口,可以用作栈或队列。 ArrayDeque 在两端快速插入和删除元素的过程中表现良好。ArrayDeque不支持插入或删除指定位置的元素。
poll()
方法用于检索并移除此队列的头部,如果此队列为空,则返回null。操作具有poll()方法的队列类通常指定它的值。
以下是poll()
方法的语法:
public E poll()
此方法没有参数。
此方法返回deque队列的头部元素,如果队列为空则返回null。
以下示例显示了poll()
方法的用法:
import java.util.ArrayDeque;
public class ArrayDequeDemo {
public static void main(String[] args) {
ArrayDeque<Integer> queue = new ArrayDeque<Integer>();
queue.add(10);
queue.add(20);
queue.add(30);
System.out.println("元素移除前队列的大小:" + queue.size());
Integer result = queue.poll();
System.out.println("移除的元素值是:" + result);
System.out.println("元素移除后队列的大小:" + queue.size());
}
}
Output:
元素移除前队列的大小:3
移除的元素值是:10
元素移除后队列的大小:2
在上述示例中,首先创建了一个ArrayDeque对象queue,添加了三个元素。然后打印队列大小,执行poll()
方法并将结果存储在变量result中,最后再次打印队列大小。我们可以看到队列内的第一个元素10已被移除,队列大小也相应地减小了。
poll()
方法在移除队列中的元素时,如果队列为空,则返回null。
poll()
方法用于检索并移除队列的头部元素,Deque类通常把它作为一种"value-returning"或"null-returning"方法的产生器。
ArrayDeque是使用可调整大小的数组实现的。当元素添加到ArrayDeque中时,如果容量不足,则会分配更大的内部数组。此方法将分配一个更大的数组并将所有要素从旧数组转移到新数组中,在数据量比较大的情况下,这可能会导致性能问题。
在并发程序中,多个线程不能同时操作一个ArrayDeque实例,否则可能会导致意想不到的结果。
ArrayDeque的poll()
方法可用于检索并移除队列的头部元素。它是一个高效的双端队列实现,可以用作栈或队列。在编写多线程应用程序时要小心,因为多个线程不能同时操作一个ArrayDeque实例。