Java 中的 Queue poll() 方法

Java 中的 Queue poll() 方法

Queue 接口poll() 方法返回并删除容器的前端元素。它删除容器中的元素。当 Queue 为空时,该方法不会抛出异常,而是返回 null 。

语法:

E poll()

返回值:

它返回容器前面或队列头部的一个元素。当 Queue 为空时,它返回 null 。

下面的程序说明了 Queue 的 poll() 方法:

程序1: 使用 LinkedList

// Java Program Demonstrate poll()
// method of Queue
  
import java.util.*;
  
public class GFG {
    public static void main(String[] args)
        throws IllegalStateException
    {
  
        // create object of Queue
        Queue<Integer> Q
            = new LinkedList<Integer>();
  
        // Add numbers to end of Queue
        Q.add(7855642);
        Q.add(35658786);
        Q.add(5278367);
        Q.add(74381793);
  
        // print queue
        System.out.println("Queue: " + Q);
  
        // print head and deletes the head
        System.out.println("Queue's head: " + Q.poll());
  
        // print head and deleted the head
        System.out.println("Queue's head: " + Q.poll());
    }
}
Queue: [7855642, 35658786, 5278367, 74381793]
Queue's head: 7855642
Queue's head: 35658786

程序2: 演示 Queue 的 poll() 方法当 Queue 变为空时的情况:

// Java Program Demonstrate poll()
// method of Queue when the Queue becomes empty
  
import java.util.*;
  
public class GFG {
    public static void main(String[] args)
        throws IllegalStateException
    {
  
        // create object of Queue
        Queue<Integer> Q
            = new LinkedList<Integer>();
  
        // Add numbers to end of Queue
        Q.add(423);
        Q.add(3432);
  
        // print queue
        System.out.println("Queue: " + Q);
  
        // print head and deletes the head
        System.out.println("Queue's head: " + Q.poll());
  
        // print head and deleted the head
        System.out.println("Queue's head: " + Q.poll());
  
        // print queue
        System.out.println("Queue: " + Q);
  
        // print null as Queue is empty now
        System.out.println("Queue's head: " + Q.poll());
    }
}
Queue: [423, 3432]
Queue's head: 423
Queue's head: 3432
Queue: []
Queue's head: null

程序3: 使用 ArrayDeque

// Java Program Demonstrate poll()
// method of Queue
  
import java.util.*;
  
public class GFG {
    public static void main(String[] args)
        throws IllegalStateException
    {
  
        // create object of Queue
        Queue<Integer> Q
            = new ArrayDeque<Integer>();
  
        // Add numbers to end of Queue
        Q.add(7855642);
        Q.add(35658786);
        Q.add(5278367);
        Q.add(74381793);
  
        // print queue
        System.out.println("Queue: " + Q);
  
        // print head and deletes头部
        System.out.println("Queue's head: " + Q.poll());
  
        // print head and deleted the head
        System.out.println("Queue's head: " + Q.poll());
    }
}
Queue: [7855642, 35658786, 5278367, 74381793]
Queue's head: 7855642
Queue's head: 35658786

程序4: 使用ConcurrentLinkedDeque进行帮助。

// Java程序演示Queue的poll()方法
 
import java.util.*;
import java.util.concurrent.ConcurrentLinkedDeque;
 
public class GFG {
    public static void main(String[] args)
        throws IllegalStateException
    {
 
        // 创建Queue对象
        Queue<Integer> Q
            = new ConcurrentLinkedDeque<Integer>();
 
        // 将数字添加到Queue的末尾
        Q.add(7855642);
        Q.add(35658786);
        Q.add(5278367);
        Q.add(74381793);
 
        // 打印队列
        System.out.println("Queue: " + Q);
 
        // 打印头部并删除头部
        System.out.println("Queue's head: " + Q.poll());
 
        // 打印头部并删除头部
        System.out.println("Queue's head: " + Q.poll());
    }
}
Queue: [7855642, 35658786, 5278367, 74381793]
Queue's head: 7855642
Queue's head: 35658786

程序5: 使用LinkedBlockingDeque进行帮助。

// Java程序演示Queue的poll()方法
 
import java.util.*;
import java.util.concurrent.LinkedBlockingDeque;
 
public class GFG {
    public static void main(String[] args)
        throws IllegalStateException
    {
 
        // 创建Queue对象
        Queue<Integer> Q
            = new LinkedBlockingDeque<Integer>();
 
        // 将数字添加到Queue的末尾
        Q.add(7855642);
        Q.add(35658786);
        Q.add(5278367);
        Q.add(74381793);
 
        // 打印队列
        System.out.println("Queue: " + Q);
 
        // 打印头部并删除头部
        System.out.println("Queue's head: " + Q.poll());
 
        // 打印头部并删除头部
        System.out.println("Queue's head: " + Q.poll());
    }
}
Queue: [7855642, 35658786, 5278367, 74381793]
Queue's head: 7855642
Queue's head: 35658786

参考文献: https://docs.oracle.com/javase/8/docs/api/java/util/Queue.html#poll–

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程