19、Java并发编程:(JUC集合)总体框架介绍

本文系统对比了Java标准集合类与JUC并发集合类,详细介绍了ArrayList、HashMap等非线程安全类,以及CopyOnWriteArrayList、ConcurrentHashMap等线程安全替代方案,帮助开发者理解和使用Java并发编程中的集合工具。

本节我们将继续学习JUC包中的集合类,我们知道jdk中本身自带了一套非线程安全的集合类,我们先温习一下java集合包里面的集合类,然后系统的看一下JUC包里面的集合类到底有什么不同。

java集合类

java集合类里面主要包含两大类:一类是Collection接口下的List、Set和Queue接口,一类是Map接口。

List的主要实现类包括:
ArrayList数组实现的队列它是一个动态数组它不是线程安全的只适用于单线程
LinkedList双重链表实现的队列它也不是线程安全的只适用于单线程
Stack表示后进先出LIFO的对象堆栈继承于Vector他是线程安全的
Vector可以实现可增长的对象数组与数组一样它包含可以使用整数索引进行访问的组件此类是线程安全的
Set的主要实现类包括:
HashSet由哈希表实际上是一个 HashMap 实例支持该集合元素不可重复它不保证 set 的迭代顺序特别是它不保证该顺序恒久不变并且此实现不是同步的
TreeSet基于 TreeMap  NavigableSet 实现也是一个没有重复元素的集合不过和HashSet不同的是TreeSet中的元素是有序的该类的实现也不是同步的
LinkedHashSet元素是有序的维护着一个运行于所有条目的双重链接列表此实现不是同步的
Map的主要实现类包括:
HashMap基于哈希表的 Map 接口的实现此实现不是同步的
TreeMap基于红黑树Red-Black tree NavigableMap 实现该类的<k,v>是有序的此实现不是同步的
HashTable与HashMap一样都是基于哈希表的Map实现但是此类是线程安全的
WeakHashMap以弱键 实现的基于哈希表的 Map WeakHashMap 当某个键不再正常使用时将自动移除其条目该类是非线程安全的

上面这些是传统的java集合类,他们大多数都不是线程安全的,所以在同步并发中对他们的使用率并不高,为了线程安全以及开发人员在使用集合工具的同时不必去维护线程安全,Doug Lea在JUC(java.util.concurrent)包中添加了java集合包中单线程类的对应的支持高并发的类。下面我们一起来看一下这些并发集合类。

JUC集合类
List的主要实现类包括:

 

CopyOnWriteArrayList:相当于线程安全的ArrayList,它实现了List接口,他是线程安全的。

Set的主要实现类包括:

 

CopyOnWriteArraySet:相当于线程安全的HashSet,内部使用 CopyOnWriteArrayList 。

ConcurrentSkipListSet:一个基于 ConcurrentSkipListMap 的可缩放并发 NavigableSet 实现,内部排序是有序的。

Map的主要实现类包括:

 

ConcurrentHashMap:支持获取的完全并发和更新的所期望可调整并发的哈希表。

ConcurrentSkipListMap:可缩放的并发 ConcurrentNavigableMap 实现,内部排序是有序的Map,该类为线程安全的。

Queue的主要实现类包括:

 

ArrayBlockingQueue:一个由数组支持的有界阻塞队列。此队列按 FIFO(先进先出)原则对元素进行排序;

LinkedBlockingQueue:一个基于已链接节点的、范围任意的 blocking queue。此队列按 FIFO(先进先出)排序元素;

LinkedBlockingDeque:一个基于已链接节点的、任选范围的阻塞双端队列;

ConcurrentLinkedQueue:一个基于链接节点的无界线程安全队列。此队列按照 FIFO(先进先出)原则对元素进行排序;

ConcurrentLinkedDeque:是双向链表实现的无界队列,该队列同时支持FIFO和FILO两种操作方式。

下一节我们将一起详细的来分析JUC中的集合工具的使用和原理。