Java 中的 LinkedBlockingDeque pop() 方法
LinkedBlockingDeque 的 pop() 方法可以从表示此双端队列的堆栈中弹出一个元素。换句话说,它删除并返回此双端队列的第一个元素。如果容器为空,则返回 null 。
语法:
public E pop()
参数: 此方法不接受任何参数。
返回值: 该方法返回此双端队列前面的元素(即表示此双端队列的堆栈的顶部)。如果队列为空,则抛出 NoSuchElementException 。
下面的程序演示了 LinkedBlockingDeque 的 pop() 方法:
程序 1:
// Java 程序演示 LinkedBlockingDeque
// 的 pop() 方法
import java.util.concurrent.LinkedBlockingDeque;
import java.util.*;
public class GFG {
public static void main(String[] args)
throws NoSuchElementException
{
// 创建 LinkedBlockingDeque 对象
LinkedBlockingDeque<Integer> LBD
= new LinkedBlockingDeque<Integer>();
// 将数字添加到队列的末尾
LBD.addFirst(7855642);
LBD.addFirst(35658786);
LBD.addFirst(5278367);
LBD.addFirst(74381793);
// 打印队列
System.out.println("LinkedBlockingDeque: " + LBD);
// 打印并删除
System.out.println("队列顶部的元素: " + LBD.pop());
// 删除队列前面的元素
System.out.println("LinkedBlockingDeque: " + LBD);
}
}
LinkedBlockingDeque: [74381793, 5278367, 35658786, 7855642]
队列顶部的元素: 74381793
LinkedBlockingDeque: [5278367, 35658786, 7855642]
程序 2:
// Java 程序演示 LinkedBlockingDeque
// 的 pop() 方法
// 当队列为空时
import java.util.concurrent.LinkedBlockingDeque;
import java.util.*;
public class GFG {
public static void main(String[] args)
{
// 创建 LinkedBlockingDeque 对象
LinkedBlockingDeque<Integer> LBD
= new LinkedBlockingDeque<Integer>();
// 将数字添加到队列的末尾
LBD.add(7855642);
LBD.add(35658786);
LBD.add(5278367);
LBD.add(74381793);
// 清空队列
LBD.clear();
System.out.println("队列顶部的元素: " + LBD.pop());
}
}
输出:
Exception in thread "main" java.util.NoSuchElementException
at java.util.concurrent.LinkedBlockingDeque.removeFirst(LinkedBlockingDeque.java:453)
at java.util.concurrent.LinkedBlockingDeque.pop(LinkedBlockingDeque.java:777)
at GFG.main(GFG.java:27)
参考文献: https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/LinkedBlockingDeque.html#pop()
极客教程