欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java concurrency之集合_動力節(jié)點Java學院整理

 更新時間:2017年06月12日 15:13:38   作者:skywang12345  
Java集合主體內容包括Collection集合和Map類;而Collection集合又可以劃分為List(隊列)和Set(集合),有需要的小伙伴可以參考下

Java集合包

Java集合主體內容包括Collection集合和Map類;而Collection集合又可以劃分為List(隊列)和Set(集合)。

1. List的實現(xiàn)類主要有: LinkedList, ArrayList, Vector, Stack。

(01) LinkedList是雙向鏈表實現(xiàn)的雙端隊列;它不是線程安全的,只適用于單線程。

(02) ArrayList是數(shù)組實現(xiàn)的隊列,它是一個動態(tài)數(shù)組;它也不是線程安全的,只適用于單線程。

(03) Vector是數(shù)組實現(xiàn)的矢量隊列,它也一個動態(tài)數(shù)組;不過和ArrayList不同的是,Vector是線程安全的,它支持并發(fā)。

(04) Stack是Vector實現(xiàn)的棧;和Vector一樣,它也是線程安全的。 

2. Set的實現(xiàn)類主要有: HastSet和TreeSet。

(01) HashSet是一個沒有重復元素的集合,它通過HashMap實現(xiàn)的;HashSet不是線程安全的,只適用于單線程。

(02) TreeSet也是一個沒有重復元素的集合,不過和HashSet不同的是,TreeSet中的元素是有序的;它是通過TreeMap實現(xiàn)的;TreeSet也不是線程安全的,只適用于單線程。 

3.Map的實現(xiàn)類主要有: HashMap,WeakHashMap, Hashtable和TreeMap。
(01) HashMap是存儲“鍵-值對”的哈希表;它不是線程安全的,只適用于單線程。

(02) WeakHashMap是也是哈希表;和HashMap不同的是,HashMap的“鍵”是強引用類型,而WeakHashMap的“鍵”是弱引用類型,也就是說當WeakHashMap 中的某個鍵不再正常使用時,會被從WeakHashMap中被自動移除。WeakHashMap也不是線程安全的,只適用于單線程。

(03) Hashtable也是哈希表;和HashMap不同的是,Hashtable是線程安全的,支持并發(fā)。

(04) TreeMap也是哈希表,不過TreeMap中的“鍵-值對”是有序的,它是通過R-B Tree(紅黑樹)實現(xiàn)的;TreeMap不是線程安全的,只適用于單線程。

更多關于這些集合類的介紹,可以參考“Java 集合系列目錄(Category)”。

為了方便,我們將前面介紹集合類統(tǒng)稱為”java集合包“。java集合包大多是“非線程安全的”,雖然可以通過Collections工具類中的方法獲取java集合包對應的同步類,但是這些同步類的并發(fā)效率并不是很高。為了更好的支持高并發(fā)任務,并發(fā)大師Doug Lea在JUC(java.util.concurrent)包中添加了java集合包中單線程類的對應的支持高并發(fā)的類。例如,ArrayList對應的高并發(fā)類是CopyOnWriteArrayList,HashMap對應的高并發(fā)類是ConcurrentHashMap,等等。

JUC包在添加”java集合包“對應的高并發(fā)類時,為了保持API接口的一致性,使用了”Java集合包“中的框架。例如,CopyOnWriteArrayList實現(xiàn)了“Java集合包”中的List接口,HashMap繼承了“java集合包”中的AbstractMap類,等等。得益于“JUC包使用了Java集合包中的類”,如果我們了解了Java集合包中的類的思想之后,理解JUC包中的類也相對容易;理解時,最大的難點是,對JUC包是如何添加對“高并發(fā)”的支持的!

JUC中的集合類

下面,我們先了解JUC包中集合類的框架;為了方便講訴,我將JUC包中的集合類劃分為3部分來進行說明。在簡單的了解JUC包中集合類的框架之后,后面的章節(jié)再逐步對各個類進行介紹。

1. List和Set

JUC集合包中的List和Set實現(xiàn)類包括: CopyOnWriteArrayList, CopyOnWriteArraySet和ConcurrentSkipListSet。

ConcurrentSkipListSet稍后在說明Map時再說明,CopyOnWriteArrayList 和 CopyOnWriteArraySet的框架如下圖所示:

(01) CopyOnWriteArrayList相當于線程安全的ArrayList,它實現(xiàn)了List接口。CopyOnWriteArrayList是支持高并發(fā)的。

(02) CopyOnWriteArraySet相當于線程安全的HashSet,它繼承于AbstractSet類。CopyOnWriteArraySet內部包含一個CopyOnWriteArrayList對象,它是通過CopyOnWriteArrayList實現(xiàn)的。

2. Map

JUC集合包中Map的實現(xiàn)類包括: ConcurrentHashMap和ConcurrentSkipListMap。它們的框架如下圖所示:

(01) ConcurrentHashMap是線程安全的哈希表(相當于線程安全的HashMap);它繼承于AbstractMap類,并且實現(xiàn)ConcurrentMap接口。ConcurrentHashMap是通過“鎖分段”來實現(xiàn)的,它支持并發(fā)。

(02) ConcurrentSkipListMap是線程安全的有序的哈希表(相當于線程安全的TreeMap); 它繼承于AbstractMap類,并且實現(xiàn)ConcurrentNavigableMap接口。ConcurrentSkipListMap是通過“跳表”來實現(xiàn)的,它支持并發(fā)。

(03) ConcurrentSkipListSet是線程安全的有序的集合(相當于線程安全的TreeSet);它繼承于AbstractSet,并實現(xiàn)了NavigableSet接口。ConcurrentSkipListSet是通過ConcurrentSkipListMap實現(xiàn)的,它也支持并發(fā)。

3. Queue

JUC集合包中Queue的實現(xiàn)類包括: ArrayBlockingQueue, LinkedBlockingQueue, LinkedBlockingDeque, ConcurrentLinkedQueue和ConcurrentLinkedDeque。它們的框架如下圖所示:

(01) ArrayBlockingQueue是數(shù)組實現(xiàn)的線程安全的有界的阻塞隊列。

(02) LinkedBlockingQueue是單向鏈表實現(xiàn)的(指定大小)阻塞隊列,該隊列按 FIFO(先進先出)排序元素。

(03) LinkedBlockingDeque是雙向鏈表實現(xiàn)的(指定大小)雙向并發(fā)阻塞隊列,該阻塞隊列同時支持FIFO和FILO兩種操作方式。

(04) ConcurrentLinkedQueue是單向鏈表實現(xiàn)的無界隊列,該隊列按 FIFO(先進先出)排序元素。

(05) ConcurrentLinkedDeque是雙向鏈表實現(xiàn)的無界隊列,該隊列同時支持FIFO和FILO兩種操作方式。

相關文章

  • Java編程中二維數(shù)組的初始化和基本操作實例

    Java編程中二維數(shù)組的初始化和基本操作實例

    這篇文章主要介紹了Java編程中二維數(shù)組的初始化和基本操作實例,是Java入門學習中的基礎知識,需要的朋友可以參考下
    2015-10-10
  • JFinal 調用存儲過程的步驟

    JFinal 調用存儲過程的步驟

    這篇文章主要介紹了JFinal 調用存儲過程的步驟,幫助大家更好的理解和學習使用JFinal,感興趣的朋友可以了解下
    2021-03-03
  • 關于訪問后端接口報404錯誤問題的解決方法(全網最細!)

    關于訪問后端接口報404錯誤問題的解決方法(全網最細!)

    404頁面的出現(xiàn)會降低用戶體驗,那么導致404頁面出現(xiàn)的原因是什么呢?這篇文章主要給大家介紹了關于訪問后端接口報404錯誤問題的解決方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-04-04
  • Mybatis-plus插入數(shù)據遇到主鍵沒有默認值的情況

    Mybatis-plus插入數(shù)據遇到主鍵沒有默認值的情況

    這篇文章主要介紹了Mybatis-plus插入數(shù)據遇到主鍵沒有默認值的情況,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Spring Cloud學習教程之Zuul統(tǒng)一異常處理與回退

    Spring Cloud學習教程之Zuul統(tǒng)一異常處理與回退

    Spring Cloud Zuul對異常的處理整體來說還是比較方便的,流程也比較清晰,下面這篇文章主要給大家介紹了關于Spring Cloud學習教程之Zuul統(tǒng)一異常處理與回退的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。
    2018-04-04
  • Java線程中的interrupt詳解

    Java線程中的interrupt詳解

    這篇文章主要介紹了Java線程中的interrupt詳解,interrupt翻譯成中文為“打斷”的意思,但實際上,interrupt()方法并非將一個線程打中斷的意思,本文提供了部分實現(xiàn)代碼,需要的朋友可以參考下
    2023-09-09
  • Java實現(xiàn)走迷宮回溯算法

    Java實現(xiàn)走迷宮回溯算法

    這篇文章主要為大家詳細介紹了Java實現(xiàn)走迷宮回溯算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Java單鏈表反轉圖文教程

    Java單鏈表反轉圖文教程

    這篇文章主要給大家介紹了關于Java單鏈表反轉的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • Java類加載器ClassLoader的使用詳解

    Java類加載器ClassLoader的使用詳解

    類加載器負責讀取Java字節(jié)代碼,并轉換成java.lang.Class類的一個實例的代碼模塊。本文主要和大家聊聊JVM類加載器ClassLoader的使用,需要的可以了解一下
    2022-12-12
  • 實例分析java開啟線程的方法

    實例分析java開啟線程的方法

    在本文里我們通過實例給大家講解了JAVA開啟線程的方法和相關知識點,需要的朋友們跟著學習下。
    2019-03-03

最新評論