網站首頁 編程語言 正文
-
隊列大小不同
ArrayBlockingQueue是有界的初始化必須指定大小,而LinkedBlockingQueue可以是有界的也可以是無界的(Integer.MAX_VALUE)。
對于LinkedBlockingQueue而言,當添加速度大于移除速度時,在無界的情況下,可能會造成內存溢出等問題。
-
數據存儲容器不同
ArrayBlockingQueue采用的是數組作為數據存儲容器,而LinkedBlockingQueue采用的則是以Node節點作為連接對象的鏈表。
由于ArrayBlockingQueue采用的是數組的存儲容器,因此在插入或刪除元素時不會產生或銷毀任何額外的對象實例,而LinkedBlockingQueue則會生成一個額外的Node對象。這可能在長時間內需要高效并發地處理大批量數據的時,對于GC可能存在較大影響。
-
兩者的實現隊列添加或移除的鎖不一樣
LinkedBlockingQueue內部由兩個ReentrantLock來實現出入隊列的線程安全,進行了鎖分離,其添加采用的是putLock,移除采用的則是takeLock,這樣能大大提高隊列的吞吐量,也意味著在高并發的情況下生產者和消費者可以并行地操作隊列中的數據,以此來提高整個隊列的并發性能。由兩個
各自
Condition對象的await和signal來實現等待和喚醒功能。ArrayBlockingQueue內部由一個ReentrantLock來實現出入隊列的線程安全,實現的隊列中的鎖是沒有分離的,即添加操作和移除操作采用的同一個ReenterLock鎖。由兩個Condition對象的await和signal來實現等待和喚醒功能。
原文鏈接:https://blog.csdn.net/qq_41139119/article/details/131367672
- 上一篇:沒有了
- 下一篇:沒有了
相關推薦
- 2023-04-07 React替換傳統拷貝方法的Immutable使用_React
- 2022-09-19 React?Hook?四種組件優化總結_React
- 2022-04-03 Golang的第一個程序-Hello?World_Golang
- 2022-06-02 Go語言的變量定義詳情_Golang
- 2022-09-09 Python中Timedelta轉換為Int或Float方式_python
- 2022-10-05 Iptables防火墻string模塊擴展匹配規則_安全相關
- 2022-06-09 教你在k8s上部署HADOOP-3.2.2(HDFS)的方法_云其它
- 2023-01-29 Redis配置外網可訪問(redis遠程連接不上)的方法_Redis
- 欄目分類
-
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支