并发容器简介

由于同步器的串行化严重降低了并发性,Java之后推出了多种并发容器,使用并发容器来替代同步容器,可以提高绳索性并降低风险

J.U.C包中提供了几个非常有用的并发容器作为线程安全的容器:

J.U.C包中提供的并发容器命名一般分为三类:

  • Concurrent:
    • 这类线程比CopyOnWrite要 高一些,但写操作代价要小一些
    • 此外,Concurrent往往提供了较低的遍历一致性,就是说容器发生改变,遍历的操作仍然不会停,在获取容器大小size的时候,容器是否为空等方法,不一定完全准确。
  • CopyOnWrite:一个线程写,多个线程读。读操作时不加锁,写操作时通过在副本上枷锁保证并发安全,空间开销大
  • Blocking:内部实现一般是基于锁,提供阻塞队列的能力

并发场景下的Map

如果对数据有一定的要求,则需使用Hashtable;

在大部分场景通常都是弱一致性 ,使用ConcurrentHashMap 即可;如果数据量 在千万级别,且存在大量增删改操作,则可以考虑使用ConcurrentSkipListMap

并发场景下的List

读多写少用CopyOnWriteArrayList

写多读少用ConcurrentLinkedQueue,需要有容量限制

相关推荐
星辰_mya6 小时前
彩云之上——[特殊字符]的架构师
java·后端·微服务·面试·架构
phltxy6 小时前
Redis 主从复制
java·数据库·redis
Full Stack Developme6 小时前
Spring-Core 解析
java·spring·rpc
BING_Algorithm7 小时前
深入理解JVM垃圾回收
jvm·后端·面试
摇滚侠7 小时前
针对主键索引的 for update 操作有什么用
java
Larry_Yanan7 小时前
QML面试常见问题(一)QML中组件呈现方式的方法有哪些
开发语言·c++·qt·ui·面试
RainCity7 小时前
Java Swing 自定义组件库分享(六)
java·笔记·后端
xuanjiong7 小时前
DDD架构Repository仓储数据流转全链路详解:Domain与其他层的数据流转
java·系统架构
knight_9___7 小时前
大模型project面试7
人工智能·python·算法·面试·大模型·agent
吴声子夜歌7 小时前
Java——类加载机制
java·开发语言·python