当前位置: 首页 > news >正文

Java线程安全集合类

Java线程安全集合类全面解析

目录

  1. 并发集合概述
  2. List线程安全实现
  3. Set线程安全实现
  4. Map线程安全实现
  5. Queue线程安全实现
  6. 总结

并发集合概述

Java提供了多种线程安全的集合类,主要分为两大类:

  1. 传统同步集合:通过synchronized关键字实现线程安全
  2. 并发集合:采用更高效的并发控制机制(如CAS、分段锁等)
Java集合
线程安全集合
同步集合
并发集合
Collections.synchronizedXXX
CopyOnWriteArrayList
ConcurrentHashMap
ConcurrentLinkedQueue

List线程安全实现

1. Vector

  • 底层结构:动态数组(类似ArrayList)
  • 线程安全机制:所有方法使用synchronized修饰
  • 缺点:性能差(全表锁)
  • 使用场景:已过时,不推荐使用
// 示例代码
Vector<String> vector = new Vector<>();
vector.add("item"); // 同步方法

2. Collections.synchronizedList

  • 底层结构:包装普通List
  • 线程安全机制:所有方法通过同步块加锁
  • 优点:兼容所有List实现
  • 缺点:迭代时需要手动同步
List<String> syncList = Collections.synchronizedList(new ArrayList<>());
// 遍历时需要手动同步
synchronized(syncList) {for(String item : syncList) {// 处理逻辑}
}

3. CopyOnWriteArrayList

  • 底层结构:volatile数组+写时复制
  • 线程安全机制
    • 读操作:无锁访问数组快照
    • 写操作:ReentrantLock+数组复制
  • 优点:读性能极高
  • 缺点:写性能差,内存占用高
  • 使用场景:读多写少(事件监听器、配置管理)
CopyOnWriteArrayList<String> cowList = new CopyOnWriteArrayList<>();
cowList.add("item"); // 加锁复制数组
String item = cowList.get(0); // 无锁读取

Set线程安全实现

1. Collections.synchronizedSet

  • 底层结构:包装普通Set
  • 线程安全机制:全方法同步
  • 缺点:性能较差

2. CopyOnWriteArraySet

  • 底层结构:基于CopyOnWriteArrayList
  • 线程安全机制:同CopyOnWriteArrayList
  • 使用场景:小型读多写少集合

3. ConcurrentSkipListSet

  • 底层结构:跳表(SkipList)
  • 线程安全机制:CAS+自旋
  • 优点:有序且并发性能好
  • 使用场景:需要有序的高并发Set
ConcurrentSkipListSet<String> set = new ConcurrentSkipListSet<>();
set.add("item"); // 线程安全

Map线程安全实现

1. Hashtable

  • 底层结构:数组+链表
  • 线程安全机制:全方法同步
  • 缺点:性能差(全表锁)
  • 使用场景:已过时,不推荐使用

2. Collections.synchronizedMap

  • 底层结构:包装普通Map
  • 线程安全机制:全方法同步
  • 缺点:迭代时需要手动同步

3. ConcurrentHashMap

  • 底层结构
    • JDK7:分段锁(Segment)
    • JDK8:数组+链表/红黑树+CAS+synchronized
  • 线程安全机制
    • 读操作:无锁(volatile读)
    • 写操作:CAS+同步块(锁住链表头节点)
  • 优点:高并发性能优异
  • 使用场景:高并发键值存储(缓存、计数器等)
ConcurrentHashMap<String, Integer> map = new ConcurrentHashMap<>();
map.put("key", 1); // 分段锁/CAS
int value = map.get("key"); // 无锁读取

Queue线程安全实现

1. ConcurrentLinkedQueue

  • 底层结构:链表+CAS
  • 线程安全机制:无锁算法(CAS)
  • 优点:高并发性能好
  • 缺点:size()方法开销大
  • 使用场景:高并发生产者消费者
ConcurrentLinkedQueue<String> queue = new ConcurrentLinkedQueue<>();
queue.offer("item"); // CAS操作
String item = queue.poll(); // CAS操作

2. BlockingQueue实现类

实现类特点使用场景
ArrayBlockingQueue有界数组+ReentrantLock固定大小队列
LinkedBlockingQueue可选有界链表+双锁通用阻塞队列
PriorityBlockingQueue优先级堆+锁优先级任务调度
SynchronousQueue直接传递+双栈线程池任务传递
DelayQueue优先级堆+锁延时任务调度
BlockingQueue<String> queue = new ArrayBlockingQueue<>(100);
queue.put("item"); // 阻塞写入
String item = queue.take(); // 阻塞取出

总结与选型建议

性能对比

集合类型读性能写性能一致性
同步集合
CopyOnWrite极好
ConcurrentHashMap极好
CAS无锁队列极好极好

选型指南

  1. List场景

    • 读多写少 → CopyOnWriteArrayList
    • 读写均衡 → Collections.synchronizedList
  2. Map场景

    • 高并发 → ConcurrentHashMap
    • 需要排序 → ConcurrentSkipListMap
  3. Queue场景

    • 无界非阻塞 → ConcurrentLinkedQueue
    • 有界阻塞 → ArrayBlockingQueue
    • 延时任务 → DelayQueue
  4. Set场景

    • 小型集合 → CopyOnWriteArraySet
    • 大型并发 → ConcurrentSkipListSet

最佳实践

  1. 优先考虑并发集合而非同步集合
  2. 根据读写比例选择合适实现
  3. 注意迭代时的线程安全问题
  4. 高并发环境避免使用size()、containsAll()等方法
// 线程安全集合使用示例
ConcurrentHashMap<String, User> cache = new ConcurrentHashMap<>();
CopyOnWriteArrayList<EventListener> listeners = new CopyOnWriteArrayList<>();
BlockingQueue<Task> taskQueue = new LinkedBlockingQueue<>(1000);

工作中我们需要根据实际情况来选择线程安全集合,这样可以在保证线程安全的同时获得最佳性能表现。

相关文章:

  • 余氯传感器在智慧水务系统中如何实现IoT集成
  • Spring Boot + Elasticsearch + HBase 构建海量数据搜索系统
  • 工厂模式 + 模板方法模式 + 策略模式的适用场景
  • 数据可视化大屏案例落地实战指南:捷码平台7天交付方法论
  • 如何选择专业数据可视化开发工具?为您拆解捷码全功能和落地指南!
  • Unity VR/MR开发-VR开发与传统3D开发的差异
  • Next.js 中间件鉴权绕过漏洞 CVE-2025-29927
  • 【前端】掌握HTML/CSS宽高调整:抓住问题根源,掌握黄金法则
  • Python 网络编程 -- WebSocket编程
  • 从零开始的云计算——番外实战,iptables防火墙项目
  • 压敏电阻的选型都要考虑哪些因素?同时注意事项都有哪些?
  • python执行测试用例,allure报乱码且未成功生成报告
  • 时序数据库IoTDB的UDF Sample算法在数据监控、故障预防的应用
  • Python html 库用法详解
  • 01 Deep learning神经网络的编程基础 二分类--吴恩达
  • Apollo Auto:Cyber RT 与 ROS 通信
  • 面试心得 --- 车载诊断测试常见的一些面试问题
  • LMT86LP模拟温度传感器
  • Mobile App UI自动化locator
  • 【websocket】安装与使用
  • 品质好的衣服品牌/百度seo排名报价
  • 公司建设网站公司/成都seo专家
  • php+mysql网站开发全程实例.pdf/想在百度做推广怎么做
  • 建筑网站汇总/搜狗推广登录
  • 网站前置审核申请报告/视频号排名优化帝搜软件
  • 企业网站建设套餐/最近营销热点