Java中Queue的poll()和remove()區(qū)別詳解
在Java中,Queue是一個接口,它有許多實現(xiàn)類,如LinkedList,PriorityQueue等。
Queue接口提供了許多方法,其中poll()和remove()是兩個常用的方法。
它們的區(qū)別在于,當隊列為空時,poll()方法返回null,而remove()方法會拋出NoSuchElementException異常。
下面是Java代碼演示poll()和remove()方法的區(qū)別:
import java.util.LinkedList; import java.util.Queue; public class QueueDemo { public static void main(String[] args) { Queue<String> queue = new LinkedList<>(); // 添加元素到隊列 queue.offer("A"); queue.offer("B"); queue.offer("C"); // 使用poll()方法獲取并移除隊列頭部的元素 System.out.println("使用poll()方法獲取并移除隊列頭部的元素:"); while(!queue.isEmpty()){ System.out.println(queue.poll()); } // 重新添加元素到隊列 queue.offer("A"); queue.offer("B"); queue.offer("C"); // 使用remove()方法獲取并移除隊列頭部的元素 System.out.println("使用remove()方法獲取并移除隊列頭部的元素:"); while(!queue.isEmpty()){ System.out.println(queue.remove()); } } }
輸出結果為:
使用poll()方法獲取并移除隊列頭部的元素:
A
B
C
使用remove()方法獲取并移除隊列頭部的元素:
A
B
C
在第一個while循環(huán)中,我們使用了poll()方法獲取并移除隊列頭部的元素,這時隊列為空,循環(huán)結束。
在第二個while循環(huán)中,我們使用了remove()方法獲取并移除隊列頭部的元素,由于隊列為空,這時會拋出NoSuchElementException異常。
到此這篇關于Java中Queue的poll()和remove()區(qū)別詳解的文章就介紹到這了,更多相關Queue的poll()和remove()內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
高效數(shù)據(jù)傳輸?shù)拿孛芪淦鱌rotobuf的使用教程
Protobuf(Protocol?Buffers)是由?Google?開發(fā)的一種輕量級、高效的數(shù)據(jù)交換格式,它被用于結構化數(shù)據(jù)的序列化、反序列化和傳輸,本文主要介紹了它的具體使用方法,需要的可以參考一下2023-05-05mybatis?@InsertProvider報錯問題及解決
這篇文章主要介紹了mybatis?@InsertProvider報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07Java加載properties文件實現(xiàn)方式詳解
這篇文章主要介紹了Java加載properties文件實現(xiàn)方式詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07MyBatis-Plus:saveOrUpdate根據(jù)指定字段更新或插入方式
這篇文章主要介紹了MyBatis-Plus:saveOrUpdate根據(jù)指定字段更新或插入方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-04-04