java中LinkedBlockingQueue與ArrayBlockingQueue的異同
相同:
1、LinkedBlockingQueue和ArrayBlockingQueue都實現(xiàn)了BlockingQueue接口;
2、LinkedBlockingQueue和ArrayBlockingQueue都是可阻塞的隊列
內(nèi)部都是使用ReentrantLock和Condition來保證生產(chǎn)和消費的同步;
當(dāng)隊列為空,消費者線程被阻塞;當(dāng)隊列裝滿,生產(chǎn)者線程被阻塞;
使用Condition的方法來同步和通信:await()和signal()
不同:
1、由上圖可以看出,他們的鎖機制不同
LinkedBlockingQueue中的鎖是分離的,生產(chǎn)者的鎖PutLock,消費者的鎖takeLock
而ArrayBlockingQueue生產(chǎn)者和消費者使用的是同一把鎖;
2、他們的底層實現(xiàn)機制也不同
LinkedBlockingQueue內(nèi)部維護的是一個鏈表結(jié)構(gòu)
在生產(chǎn)和消費的時候,需要創(chuàng)建Node對象進行插入或移除,大批量數(shù)據(jù)的系統(tǒng)中,其對于GC的壓力會比較大
而ArrayBlockingQueue內(nèi)部維護了一個數(shù)組
在生產(chǎn)和消費的時候,是直接將枚舉對象插入或移除的,不會產(chǎn)生或銷毀任何額外的對象實例
3、構(gòu)造時候的區(qū)別
LinkedBlockingQueue有默認(rèn)的容量大小為:Integer.MAX_VALUE,當(dāng)然也可以傳入指定的容量大小
ArrayBlockingQueue在初始化的時候,必須傳入一個容量大小的值
看其提供的構(gòu)造方法就能知道
4、執(zhí)行clear()方法
LinkedBlockingQueue執(zhí)行clear方法時,會加上兩把鎖
5、統(tǒng)計元素的個數(shù)
LinkedBlockingQueue中使用了一個AtomicInteger對象來統(tǒng)計元素的個數(shù)
ArrayBlockingQueue則使用int類型來統(tǒng)計元素
相關(guān)文章
Spring?Boot:Idea從零開始初始化后臺項目的教程
這篇文章主要介紹了Spring?Boot:Idea從零開始初始化后臺項目的教程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12Java使用Thread和Runnable的線程實現(xiàn)方法比較
這篇文章主要介紹了Java使用Thread和Runnable的線程實現(xiàn)方法,結(jié)合實例形式對比分析了Java使用Thread和Runnable實現(xiàn)與使用線程的相關(guān)操作技巧,需要的朋友可以參考下2019-10-10OKHttp3(支持Retrofit)的網(wǎng)絡(luò)數(shù)據(jù)緩存Interceptor攔截器的實現(xiàn)
本篇文章主要介紹了OKHttp3(支持Retrofit)的網(wǎng)絡(luò)數(shù)據(jù)緩存Interceptor攔截器的實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12Java啟動參數(shù)(-,?-X,?-XX參數(shù))的使用
本文主要介紹了Java啟動參數(shù)(-,?-X,?-XX參數(shù))的使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06Hibernate使用hbm.xml配置映射關(guān)系解析
這篇文章主要介紹了Hibernate使用hbm.xml配置映射關(guān)系解析,具有一定參考價值,需要的朋友可以了解下。2017-11-11基于SpringBoot實現(xiàn)自動裝配返回屬性的設(shè)計思路
這篇文章主要介紹了基于SpringBoot實現(xiàn)自動裝配返回屬性,這里涉及到的技術(shù)知識點有注解解析器,為什么用ResponseBodyAdvice這里解析?不在Filter,Interceptors,本文結(jié)合示例代碼給大家介紹的非常詳細,需要的朋友參考下吧2022-03-03