AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

JDK并發編程類庫,有坑!!!

來源: 責編: 時間:2024-05-29 17:31:46 178觀看
導讀大家好,我是冰河~~在JDK1.5之前的線程安全的容器,大多數都是指同步容器,使用同步容器進行并發編程時,最大的問題就是性能很差。因為同步容器中的所有方法都是使用synchronized鎖進行互斥,串行度太高了,無法真正的做到并行。

pAJ28資訊網——每日最新資訊28at.com

大家好,我是冰河~~pAJ28資訊網——每日最新資訊28at.com

在JDK1.5之前的線程安全的容器,大多數都是指同步容器,使用同步容器進行并發編程時,最大的問題就是性能很差。因為同步容器中的所有方法都是使用synchronized鎖進行互斥,串行度太高了,無法真正的做到并行。pAJ28資訊網——每日最新資訊28at.com

所以,在JDK1.5之后,JDK中提供了并發性能更好的容器。JDK1.5及之后的版本中,提供的線程安全的容器,一般被稱為并發容器。pAJ28資訊網——每日最新資訊28at.com

并發容器

與同步容器一樣,并發容器在總體上也可以分為四大類,分別為:List、Set、Map和Queue。總體上如下圖所示。pAJ28資訊網——每日最新資訊28at.com

圖片pAJ28資訊網——每日最新資訊28at.com

接下來,我們分別介紹下這些并發容器在使用時的注意事項和避免踩到的坑。pAJ28資訊網——每日最新資訊28at.com

List

并發容器中的List相對來說比較簡單,就一個CopyOnWriteArrayList。大家可以從字面的意思中就能夠體會到:CopyOnWrite,在寫的時候進行復制操作,也就是說在進行寫操作時,會將共享變量復制一份。那這樣做有什么好處呢?最大的好處就是:讀操作可以做到完全無鎖化pAJ28資訊網——每日最新資訊28at.com

在CopyOnWriteArrayList內部維護了一個數組,成員變量array指向這個數組,其核心源代碼如下所示。pAJ28資訊網——每日最新資訊28at.com

private transient volatile Object[] array;final Object[] getArray() { return array;}final void setArray(Object[] a) { array = a;}

當進行操作時,都是基于array指向的這個內部數組進行的。例如,我們使用Iterator迭代器遍歷這個數組時,會按照下圖所示的方式進行讀操作。pAJ28資訊網——每日最新資訊28at.com

圖片pAJ28資訊網——每日最新資訊28at.com

如果在遍歷CopyOnWriteArrayList時發生寫操作,例如,向數組中增加一個元素時,CopyOnWriteArrayList則會將內部的數組復制一份出來,然后會在新復制出來的數組上添加新的元素,添加完再將array指向新的數組,如下圖所示。pAJ28資訊網——每日最新資訊28at.com

圖片pAJ28資訊網——每日最新資訊28at.com

對于CopyOnWriteArrayList的其他寫操作和添加元素的操作原理相同,這里就不再贅述了。pAJ28資訊網——每日最新資訊28at.com

使用CopyOnWriteArrayList時需要注意的是:pAJ28資訊網——每日最新資訊28at.com

  • CopyOnWriteArrayList只適合寫操作比較少的場景,并且能夠容忍讀寫操作在短時間內的不一致。
  • CopyOnWriteArrayList的迭代器是只讀的,不支持寫操作。

Set

對于Set接口來說,并發容器中主要有兩個實現類,一個是CopyOnWriteArraySet,另一個是ConcurrentSkipListSet。其中,CopyOnWriteArraySet的使用場景、原理與注意事項和CopyOnWriteArrayList一致。而ConcurrentSkipListSet的使用場景、原理和注意事項和下文的ConcurrentSkipListMap一致。這里,我就不再贅述啦。pAJ28資訊網——每日最新資訊28at.com

Map

在并發容器中,Map接口的實現類主要有ConcurrentHashMap和ConcurrentSkipListMap,而ConcurrentHashMap和ConcurrentSkipListMap最大的區別就是:ConcurrentHashMap的Key是無序的,而ConcurrentSkipListMap的Key是有序的。pAJ28資訊網——每日最新資訊28at.com

在使用ConcurrentHashMap和ConcurrentSkipListMap時,需要注意的是:ConcurrentHashMap和ConcurrentSkipListMap的Key和Value都不能為空。pAJ28資訊網——每日最新資訊28at.com

這里,我們可以將Map相關的類總結成一個表格,如下所示。pAJ28資訊網——每日最新資訊28at.com

Map的實現類
pAJ28資訊網——每日最新資訊28at.com

Key是否可為空
pAJ28資訊網——每日最新資訊28at.com

Value是否可為空
pAJ28資訊網——每日最新資訊28at.com

是否是線程安全的
pAJ28資訊網——每日最新資訊28at.com

HashMap
pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com

TreeMap
pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com

HashTable
pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com

ConcurrentHashMap
pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com

ConcurrentSkipListMap
pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com


pAJ28資訊網——每日最新資訊28at.com

這樣,大家記憶起來就方便多了。pAJ28資訊網——每日最新資訊28at.com

這里,ConcurrentSkipListMap是基于“跳表”實現的,跳表的插入、刪除、查詢的平均時間復雜度為O(log n),這些時間復雜度在理論上與線程數沒有關系。如果要追求性能的話,可以嘗試使用ConcurrentSkipListMap。pAJ28資訊網——每日最新資訊28at.com

Queue

在Java的并發容器中,Queue相對來說比較復雜。我們先來了解幾個概念:pAJ28資訊網——每日最新資訊28at.com

  • 阻塞隊列:阻塞一般就是指當隊列已滿時,入隊操作會阻塞;當隊列為空時,出隊操作就會阻塞。
  • 非阻塞隊列:隊列的入隊和出隊操作不會阻塞。
  • 單端隊列:隊列的入隊操作只能在隊尾進行,隊列的出隊操作只能在隊首進行。
  • 雙端隊列:隊列的入隊操作和出隊操作都可以在隊首和隊尾進行。

我們可以將上述的隊列進行組合,將隊列分為單端阻塞隊列、雙端阻塞隊列、單端非阻塞隊列和雙端非阻塞隊列。pAJ28資訊網——每日最新資訊28at.com

圖片pAJ28資訊網——每日最新資訊28at.com

在Java的并發容器中,會使用明顯的標識來區分不同類型的隊列。pAJ28資訊網——每日最新資訊28at.com

  • 阻塞隊列一個明顯的標識就是使用Blocking修飾,例如,ArrayBlockingQueue和LinkedBlockingQueue都是阻塞隊列。
  • 單端隊列會使用Queue標識,例如ArrayBlockingQueue和LinkedBlockingQueue也是單端隊列。
  • 雙端隊列會使用Deque標識,例如LinkedBlockingDeque和ConcurrentLinkedDeque都是雙端隊列。

接下來,我們就分別簡單聊聊這四種類型的隊列。pAJ28資訊網——每日最新資訊28at.com

單端阻塞隊列

在Java的并發容器中,單端阻塞隊列的主要實現是BlockingQueue,主要包括:ArrayBlockingQueue、LinkedBlockingQueue、SynchronousQueue、LinkedTransferQueue、PriorityBlockingQueue和DelayQueue。pAJ28資訊網——每日最新資訊28at.com

圖片pAJ28資訊網——每日最新資訊28at.com

單端阻塞隊列的內部一般會有一個隊列。pAJ28資訊網——每日最新資訊28at.com

在實現上,內部的隊列可以是數組,例如ArrayBlockingQueue,也可以是鏈表,例如LinkedBlockingQueue。pAJ28資訊網——每日最新資訊28at.com

也可以在內部不存在隊列,例如SynchronousQueue,SynchronousQueue實現了生產者的入隊操作必須等待消費者的出隊操作完成之后才能進行。pAJ28資訊網——每日最新資訊28at.com

LinkedTransferQueue集成了LinkedBlockingQueue和SynchronousQueue的優點,并且性能比LinkedBlockingQueue好。pAJ28資訊網——每日最新資訊28at.com

PriorityBlockingQueue實現了按照優先級進行出隊操作,也就是說,隊列元素在PriorityBlockingQueue內部可以按照某種規則進行排序。pAJ28資訊網——每日最新資訊28at.com

DelayQueue是延時隊列,實現了在一段時間后再出隊的操作。pAJ28資訊網——每日最新資訊28at.com

雙端阻塞隊列

雙端阻塞隊列的實現主要是LinkedBlockingDeque。示意圖如下所示。pAJ28資訊網——每日最新資訊28at.com

圖片pAJ28資訊網——每日最新資訊28at.com

單端非阻塞隊列

單端非阻塞隊列的實現主要是ConcurrentLinkedQueue,示意圖如下所示。pAJ28資訊網——每日最新資訊28at.com

圖片pAJ28資訊網——每日最新資訊28at.com

雙端非阻塞隊列

雙端非阻塞隊列的實現主要是ConcurrentLinkedDeque,示意圖如下所示。pAJ28資訊網——每日最新資訊28at.com

圖片pAJ28資訊網——每日最新資訊28at.com

有界與無界隊列

使用隊列時,還要注意隊列的有界與無界問題,也就是在使用隊列時,需要注意隊列是否有容量限制。pAJ28資訊網——每日最新資訊28at.com

在實際工作中,一般推薦使用有界隊列。因為無界隊列很容易導致內存溢出的問題。在Java的并發容器中,只有ArrayBlockingQueue和LinkedBlockingQueue支持有界,其他的隊列都是無界隊列。pAJ28資訊網——每日最新資訊28at.com

在使用時,一定要注意內存溢出問題。pAJ28資訊網——每日最新資訊28at.com

總結

今天我們主要介紹了JDK1.5之后提供的并發容器,主要包括:List、Set、Map和Queue,而Queue又可以分為:單端阻塞隊列、雙端阻塞隊列、單端非阻塞隊列和雙端非阻塞隊列。對于每種并發容器,我們簡單介紹了其基本原理和注意事項。pAJ28資訊網——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-91530-0.htmlJDK并發編程類庫,有坑!!!

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 你管這玩意兒叫負載均衡?

下一篇: 一個 Python 對象會在何時被銷毀?

標簽:
  • 熱門焦點
  • vivo TWS Air開箱體驗:真輕 臻好聽

    在vivo S15系列新機的發布會上,vivo的最新款真無線藍牙耳機vivo TWS Air也一同發布,本次就這款耳機新品給大家帶來一個簡單的分享。外包裝盒上,vivo TWS Air保持了vivo自家產
  • 6月安卓手機性價比榜:Note 12 Turbo斷層式碾壓

    6月份有一個618,雖然這是京東周年慶的日子,但別的電商也都不約而同的跟進了,反正促銷沒壞處,廠商和用戶都能滿意。618期間一些產品也出現了歷史低價,那么各個價位段的產品性價比
  • Raft算法:保障分布式系統共識的穩健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可復制、可冗余、可容錯”)的首字母縮寫。Raft算法是一種用于在分布式系統
  • 得物效率前端微應用推進過程與思考

    一、背景效率工程隨著業務的發展,組織規模的擴大,越來越多的企業開始意識到協作效率對于企業團隊的重要性,甚至是決定其在某個行業競爭中突圍的關鍵,是企業長久生存的根本。得物
  • 讓我們一起聊聊文件的操作

    文件【1】文件是什么?文件是保存數據的地方,是數據源的一種,比如大家經常使用的word文檔、txt文件、excel文件、jpg文件...都是文件。文件最主要的作用就是保存數據,它既可以保
  • 2023年,我眼中的字節跳動

    此時此刻(2023年7月),字節跳動從未上市,也從未公布過任何官方的上市計劃;但是這并不妨礙它成為中國最受關注的互聯網公司之一。從2016-17年的抖音強勢崛起,到2018年的“頭騰
  • 電視息屏休眠仍有網絡上傳 愛奇藝被質疑“薅消費者羊毛”

    記者丨寧曉敏 見習生丨汗青出品丨鰲頭財經(theSankei) 前不久,愛奇藝發布了一份亮眼的一季報,不僅營收和會員營收創造歷史最佳表現,其運營利潤也連續6個月實現增長。自去年年初
  • 8月見!小米MIX Fold 3獲得3C認證:支持67W快充

    這段時間以來,包括三星、一加、榮耀等等有不少品牌旗下的最新折疊屏旗艦都得到了不少爆料,而小米新一代折疊屏旗艦——小米MIX Fold 3此前也屢屢被傳
  • 聯想小新Pad Pro 12.6將要推出,搭載高通驍龍 870 處理器

    聯想小新Pad Pro 12.6將于秋季新品會上推出,官方按照慣例直接在發布會前給出了機型的所有參數。聯想小新 Pad Pro 12.6 將搭載高通驍龍 870 處理器,重量為 5
Top