并发线程安全的集合

举报
xcc-2022 发表于 2022/07/22 11:44:08 2022/07/22
【摘要】 Java线程安全StampedLockJava线程安全Lock、ReentrantLock、ReentrantReadWriteLockJava线程安全集合总结Java原子操作Atomic文章目录线程安全的集合把不安全的集合转化成线程安全的从Java5开始,在Java.util.concurrent包下提供了大量支持高效并发访问的集合接口和实现类,如下图:从图中可以看出,这些线程安全的集合主...

Java线程安全StampedLock
Java线程安全Lock、ReentrantLock、ReentrantReadWriteLock
Java线程安全集合总结
Java原子操作Atomic



从Java5开始,在Java.util.concurrent包下提供了大量支持高效并发访问的集合接口和实现类,如下图:

在这里插入图片描述

从图中可以看出,这些线程安全的集合主要分为两类,以Concurrent开头的集合类和以CopyOnWrite开头的集合类。

1、以Concurrent开头的集合类,可以支持多个线程并发写入访问,写入操作都是线程安全的,读取操作不必锁定,采用更复杂的算法保证永不会锁住整个集合,因此在并发写入时有较好的性能。
ConcurrentLinkedQueue实现多线程高效、无须等待的访问,不能使用null元素。
ConcurrentLinkedQueue和ConcurrentHashMap最好不要使用迭代器,因为迭代器可能不能反映出创建迭代器后所做的修改,但程序不会出现异常。

2、以CopyOnWrite开头的集合类,采用复制底层数组的方式来实现写操作,读时无须加锁,对复制的新数组进行写操作,所以线程安全,频繁的复制数组,性能比较差,但读操作因为没有加锁和阻塞就很快、很安全

线程安全的集合

val list = CopyOnWriteArrayList<String>()
val map = ConcurrentHashMap<String, String>()
val set = CopyOnWriteArraySet<String>()

把不安全的集合转化成线程安全的

  • List
val unsafeList = ArrayList<String>()
//方式一
val list = Collections.synchronizedList(unsafeList)
//方式二
val list = CopyOnWriteArrayList(unsafeList)
  • Map
val unsafeMap = HashMap<String, String>()
//方式一
val map = Collections.synchronizedMap(unsafeMap)
//方式二
val map = ConcurrentHashMap(unsafeMap)
  • Set
val unsafeSet = HashSet<String>()
//方式一
val set = Collections.synchronizedSet(unsafeSet)
//方式二
val set = CopyOnWriteArraySet(unsafeSet)
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。