并發(fā)編程ConcurrentLinkedQueue示例詳解
ConcurrentLinkedQueue
ConcurrentLinkedQueue是非阻塞線程安全的隊列,適用于高并發(fā)的場景。是一個基于鏈接節(jié)點的無界線程安全隊列,按照 FIFO(先進先出)原則對元素進行排序。隊列元素中不可以放置null元素(內(nèi)部實現(xiàn)的特殊節(jié)點除外)
ConcurrentLinkedQueue原理
- ConcurrentLinked是由鏈表結構組成的線程安全的先進先出無界隊列。
- 當多線程要共享訪問集合時,ConcurrentLinkedQueue是一個比較好的選擇。
- 不允許插入null元素
- 支持非阻塞地訪問并發(fā)安全的隊列,不會拋出ConcurrentModifiationException異常。
- size方法不是準確的,因為在統(tǒng)計集合的時候,隊列可能正在添加元素,導致統(tǒng)計不準。
- 批量操作addAll、removeAll、retainAll、containsAll、equals和toArray不保證原子性(操作不可分割)
- 添加元素happen-before其他線程移除元素。
ConcurrentLinkedQueue類繼承AbstractQueue抽象類
具有隊列的功能;實現(xiàn)了Queue接口,可作為隊列使用。
- ConcurrentLinkedQueue繼承于AbstractQueue。
- ConcurrentLinkedQueue內(nèi)部是通過鏈表來實現(xiàn)的。同時包含鏈表的頭節(jié)點head和尾節(jié)點tail。
- ConcurrentLinkedQueue按照 FIFO(先進先出)原則對元素進行排序。元素都是從尾部插入到鏈表,從頭部開始返回。
- ConcurrentLinkedQueue的鏈表Node中的next的類型是volatile,而且鏈表數(shù)據(jù)item的類型也是volatile。ConcurrentLinkedQueue就是通過volatile來實現(xiàn)多線程對競爭資源的互斥訪問的。
- 其中head節(jié)點存放鏈表第一個item為null的節(jié)點,tail則并不是總指向最后一個節(jié)點
ConcurrentLinkedQueue操作方法
private transient volatile Node<E> head; private transient volatile Node<E> tail; public ConcurrentLinkedQueue() { head = tail = new Node<E>(null); }
構造函數(shù)中,新建了一個“內(nèi)容為null的節(jié)點”,并設置表頭head和表尾tail的值為新節(jié)點。 head和tail是volatile類型,具有volatile賦予的含義:“即對一個volatile變量的讀,總是能看到(任意線程)對這個volatile變量最后的寫入”。
private static class Node<E> { volatile E item; volatile Node<E> next; Node(E item) { UNSAFE.putObject(this, itemOffset, item); } }
Node是單向鏈表節(jié)點,next指向下一個Node,item用于存儲數(shù)據(jù)。Node中操作節(jié)點數(shù)據(jù)的API,是通過Unsafe機制的CAS函數(shù)實現(xiàn)的;例如casNext()是通過CAS函數(shù)“比較并設置節(jié)點的下一個節(jié)點”。
1、添加
以add(E e)為例對ConcurrentLinkedQueue中的添加
public boolean add(E e) { return offer(e); }
add()實際上是調(diào)用的offer()來完成添加操作的;offer(E e)的作用就是將元素e添加到鏈表的末尾。
2、刪除
poll():在鏈表頭部獲取并且移除一個元素
poll()的作用就是刪除鏈表的表頭節(jié)點,并返回被刪節(jié)點對應的值。
3、peek操作
peek操作是獲取鏈表頭部一個元素(只讀取不移除)。
以上就是并發(fā)編程ConcurrentLinkedQueue示例詳解的詳細內(nèi)容,更多關于并發(fā)編程ConcurrentLinkedQueue的資料請關注腳本之家其它相關文章!
相關文章
Java模擬棧和隊列數(shù)據(jù)結構的基本示例講解
這篇文章主要介紹了Java模擬棧和隊列數(shù)據(jù)結構的基本示例,棧的后進先出和隊列的先進先出是數(shù)據(jù)結構中最基礎的知識,本文則又對Java實現(xiàn)棧和隊列結構的方法進行了細分,需要的朋友可以參考下2016-04-04SpringBoot?基于?MongoTemplate?的工具類過程詳解
MongoDB是一個高性能,開源,無模式的文檔型數(shù)據(jù)庫,是當前NoSql數(shù)據(jù)庫中比較熱門的一種,這篇文章主要介紹了SpringBoot基于MongoTemplate的工具類,需要的朋友可以參考下2023-09-09SpringBoot?web靜態(tài)資源映射實現(xiàn)步驟詳解
在springBoot中的靜態(tài)資源的映射是通過SpringMVC中的resourceHttpRequestHandler來進行實現(xiàn)的。在該請求映射器中默認規(guī)定了,SpringBoot會將classPath或者ServletContext下的/static?(/public、/resources?或?/META-INF/resources)目錄中,存放靜態(tài)資源2022-09-09