Java中的ConcurrentLinkedQueue使用解析
定義
一個(gè)基于鏈接節(jié)點(diǎn)的無界線程安全隊(duì)列。此隊(duì)列按照 FIFO(先進(jìn)先出)原則對(duì)元素進(jìn)行排序。
隊(duì)列的頭部是隊(duì)列中時(shí)間最長(zhǎng)的元素。
隊(duì)列的尾部是隊(duì)列中時(shí)間最短的元素。 新的元素插入到隊(duì)列的尾部,隊(duì)列獲取操作從隊(duì)列頭部獲得元素。
當(dāng)多個(gè)線程共享訪問一個(gè)公共 collection 時(shí),ConcurrentLinkedQueue 是一個(gè)恰當(dāng)?shù)倪x擇。
此隊(duì)列不允許使用 null 元素。
函數(shù)
- offer(E e) 將指定元素插入此隊(duì)列的尾部。
- poll() 獲取并移除此隊(duì)列的頭,如果此隊(duì)列為空,則返回 null
- add() 與offer(E e)完全一樣,都是往隊(duì)列尾部添加元素
- peek() 獲取但不移除此隊(duì)列的頭;如果此隊(duì)列為空,則返回 null
- remove(Object o) 從隊(duì)列中移除指定元素的單個(gè)實(shí)例(如果存在)
- contains(Object o) 如果此隊(duì)列包含指定元素,則返回 true
- toArray() 返回以恰當(dāng)順序包含此隊(duì)列所有元素的數(shù)組
- toArray(T[] a) 返回以恰當(dāng)順序包含此隊(duì)列所有元素的數(shù)組;返回?cái)?shù)組的運(yùn)行時(shí)類型是指定數(shù)組的運(yùn)行時(shí)類型
- size() 返回此隊(duì)列中的元素?cái)?shù)量
- isEmpty 返回隊(duì)列是否為空
注意:當(dāng)需要判斷隊(duì)列是否有值時(shí),推薦使用isEmpty(),size()的時(shí)間復(fù)雜度是o(n),當(dāng)數(shù)據(jù)量很大時(shí),會(huì)比isEmpty()消耗明顯多的時(shí)間。
下面比較一下isEmpty()和size()耗時(shí):
public class ConcurrentLinkedQueueTest { private static final Logger logger = LoggerFactory.getLogger(ConcurrentLinkedQueueTest.class); public static void main(String args[]) throws InterruptedException { ConcurrentLinkedQueue<String> queue = new ConcurrentLinkedQueue<String>(); int serviceNum = 10;//服務(wù)窗口數(shù) int perpeoNum = 10000;//買車票人數(shù) CountDownLatch countDownLatch = new CountDownLatch(serviceNum);//初始值是線程的個(gè)數(shù) //將買票人數(shù)放入隊(duì)列 for(int i=0; i<perpeoNum; i++){ queue.add("買票人_" + i); } //執(zhí)行10個(gè)線程從隊(duì)列取出買票人 logger.info("-----開始賣票了--------"); long start = System.currentTimeMillis(); ExecutorService service = Executors.newFixedThreadPool(10); for(int i=0; i<serviceNum; i++){ service.submit(new Windows("窗口號(hào)_" + i , queue, countDownLatch)); } //等待所有線程都執(zhí)行完,主線程再執(zhí)行。 countDownLatch.await(); logger.info("-----所有人都買完票了----"); long time = System.currentTimeMillis() - start; logger.info("總消耗時(shí)間是:{}",time); service.shutdown(); } private static class Windows implements Runnable{ private String name; private ConcurrentLinkedQueue queue; private CountDownLatch countDownLatch; public Windows(String name, ConcurrentLinkedQueue queue, CountDownLatch countDownLatch){ this.name = name; this.queue = queue; this.countDownLatch = countDownLatch; } @Override public void run() { // while (!queue.isEmpty()){ while(queue.size() > 0){ logger.info(queue.poll() + "---買票完畢---{}", name ); } countDownLatch.countDown();//線程執(zhí)行完,count值-1 } } }
執(zhí)行結(jié)果: 使用size(),耗時(shí)511ms; 使用isEmpty(),耗時(shí)125ms; 所以優(yōu)先使用isEmpty();
CountDownLatch
CountDownLatch是一個(gè)非常實(shí)用的多線程控制工具類,例如,應(yīng)用程序的主線程希望在負(fù)責(zé)啟動(dòng)框架服務(wù)的線程已經(jīng)啟動(dòng)所有的框架服務(wù)之后再執(zhí)行。
CountDownLatch是通過一個(gè)計(jì)數(shù)器來實(shí)現(xiàn)的,計(jì)數(shù)器的初始值為線程的數(shù)量。
每當(dāng)一個(gè)線程完成了自己的任務(wù)后,計(jì)數(shù)器的值就會(huì)減1。
當(dāng)計(jì)數(shù)器值到達(dá)0時(shí),它表示所有的線程已經(jīng)完成了任務(wù),然后在閉鎖上等待的線程就可以恢復(fù)執(zhí)行任務(wù)。
到此這篇關(guān)于Java中的ConcurrentLinkedQueue使用解析的文章就介紹到這了,更多相關(guān)ConcurrentLinkedQueue使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot基于redis自定義注解實(shí)現(xiàn)后端接口防重復(fù)提交校驗(yàn)
本文主要介紹了SpringBoot基于redis自定義注解實(shí)現(xiàn)后端接口防重復(fù)提交校驗(yàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01在IDEA中實(shí)現(xiàn)同時(shí)運(yùn)行2個(gè)相同的java程序
這篇文章主要介紹了在IDEA中實(shí)現(xiàn)同時(shí)運(yùn)行2個(gè)相同的java程序,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02Spring框架中的重要注解及其應(yīng)用代碼實(shí)例
Spring框架廣泛應(yīng)用于多種場(chǎng)景中,下面這篇文章主要給大家介紹了關(guān)于Spring框架中重要注解及其應(yīng)用的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-08-08Java8新特性之重復(fù)注解(repeating annotations)淺析
這篇文章主要介紹了Java8新特性之重復(fù)注解(repeating annotations)淺析,這個(gè)新特性只是修改了程序的可讀性,是比較小的一個(gè)改動(dòng),需要的朋友可以參考下2014-06-06Java實(shí)現(xiàn)讀取及生成Excel文件的方法
這篇文章主要介紹了Java實(shí)現(xiàn)讀取及生成Excel文件的方法,結(jié)合實(shí)例形式分析了java通過引入第三方j(luò)ar包poi-3.0.1-FINAL-20070705.jar實(shí)現(xiàn)針對(duì)Excel文件的讀取及生成功能,需要的朋友可以參考下2017-12-12SpringBoot2.0.3打印默認(rèn)數(shù)據(jù)源為 HikariDataSource (null)問題
這篇文章主要介紹了SpringBoot2.0.3打印默認(rèn)數(shù)據(jù)源為 HikariDataSource (null)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10java局部變量表的基礎(chǔ)知識(shí)點(diǎn)及實(shí)例
在本篇文章里小編給大家整理的是一篇關(guān)于java局部變量表的基礎(chǔ)知識(shí)點(diǎn)及實(shí)例,有需要的朋友們可以學(xué)習(xí)參考下。2021-06-06Java中的ArrayList和contains函數(shù)和擴(kuò)容機(jī)制(源碼詳解)
這篇文章主要介紹了Java中的ArrayList和contains函數(shù)和擴(kuò)容機(jī)制,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-10-10