中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》
  • 首頁 > 
  • 教程 > 
  • 開發技術 > 
  • java并發編程工具類JUC之LinkedBlockingQueue鏈表隊列的示例分析

java并發編程工具類JUC之LinkedBlockingQueue鏈表隊列的示例分析

發布時間:2021-06-04 10:42:59 來源:億速云 閱讀:180 作者:小新 欄目:開發技術

小編給大家分享一下java并發編程工具類JUC之LinkedBlockingQueue鏈表隊列的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

java.util.concurrent.LinkedBlockingQueue 是一個基于單向鏈表的、范圍任意的(其實是有界的)、FIFO阻塞隊列。訪問與移除操作是在隊頭進行,添加操作是在隊尾進行,并分別使用不同的鎖進行保護,只有在可能涉及多個節點的操作才同時對兩個鎖進行加鎖。

隊列是否為空、是否已滿仍然是通過元素數量的計數器(count)進行判斷的,由于可以同時在隊頭、隊尾并發地進行訪問、添加操作,所以這個計數器必須是線程安全的,這里使用了一個原子類 AtomicInteger,這就決定了它的容量范圍是: 1 –Integer.MAX_VALUE。

在之前的文章中已經為大家介紹了java并發編程的工具:BlockingQueue接口、ArrayBlockingQueue、DelayQueue。

LinkedBlockingQueue 隊列是BlockingQueue接口的實現類,所以它具有BlockingQueue接口的一切功能特點。LinkedBlockingQueue隊列 按照first-in-first-out (FIFO)先進先出的方式對元素進行排序。LinkeBlockingQueue 提供了兩種構造函數,一個構造函數構造一個隊列容量為固定個數的隊列,另一個無參構造函數構造一個隊列容量為Integer.MAX_VALUE的隊列.

public LinkedBlockingQueue() {
    this(Integer.MAX_VALUE);
}

public LinkedBlockingQueue(int capacity) {
    if (capacity <= 0) throw new IllegalArgumentException();
    this.capacity = capacity;
    last = head = new Node<E>(null);
}

ArrayBlockingQueue和LinkedBlockingQueue對比

ArrayBlockingQueue和LinkedBlockingQueue都是實現BlockingQueue接口,所以在使用方式上是一致的,下面我們就不介紹使用方法,而是從二者的性能及底層數據結構的實現角度進行

ArrayBlockingQueue插入和刪除數據,只采用了一個lock鎖,讀取和寫入操作無法并行。 所以在高并發場景下執行效率會比LinkedBlockingQueue慢一些。

java并發編程工具類JUC之LinkedBlockingQueue鏈表隊列的示例分析

LinkedBlockingQueue采用“two lock queue”算法變體,雙鎖(ReentrantLock):takeLock、putLock,允許讀寫并行,remove(e)和迭代器iterators需要獲取2個鎖。這樣可以降低線程由于線程無法獲取到lock而進入WAITING狀態的可能性,從而提高了線程并發執行的效率。

java并發編程工具類JUC之LinkedBlockingQueue鏈表隊列的示例分析

ArrayBlockingQueue底層代碼是采用數組實現的,創建的時候必須指定隊列的容量并分配存儲空間;LinkedBlockingQueue采用的是鏈表數據結構實現的,其鏈表節點的存儲空間分配是動態的,新的元素對象加入隊列分配空間,元素對象從隊列取出之后存儲空間GC,初始化時指定的是隊列的最大容量。但是使用鏈表數據結構既是LinkedBlockingQueue優勢也是它的劣勢,高并發場景下由于空間動態分配需要java JVM頻繁的進行垃圾回收。

總體來說在并發場景下,LinkedBlockingQueue的吞吐量比ArrayBlockingQueue更好。但是在java實現高性能隊列的首選是disruptor,它不是JDK自帶的。java程序員非常熟悉的Log4j2底層性能比logback和log4j有了較大的提升,究其原因就是使用了disruptor高性能隊列實現的異步日志

以上是“java并發編程工具類JUC之LinkedBlockingQueue鏈表隊列的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

基隆市| 乃东县| 论坛| 湘阴县| 墨玉县| 鄂伦春自治旗| 凌云县| 孝感市| 政和县| 长乐市| 若羌县| 江油市| 平阴县| 定安县| 舞钢市| 调兵山市| 景泰县| 中方县| 司法| 普陀区| 综艺| 焦作市| 色达县| 宜兰县| 西城区| 乾安县| 漳州市| 广饶县| 敦化市| 曲周县| 山东| 永登县| 黑龙江省| 临江市| 五峰| 敦煌市| 曲靖市| 胶州市| 余姚市| 峨山| 惠州市|