Map、List、Set 分别说下线程安全类和线程不安全的类

2023-12-19 02:12

本文主要是介绍Map、List、Set 分别说下线程安全类和线程不安全的类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

​    ​嗨,大家好,欢迎来到程序猿漠然公众号,我是漠然。
Map、List、Set 是 Java 中非常常用的集合类,它们在多线程环境下有各自的线程安全类和线程不安全的类。本文将分别介绍这三个集合类型的线程安全类和线程不安全的类,并举例说明。 一、Map

  1. 线程安全的类:ConcurrentHashMap ConcurrentHashMap 是 Java 提供的一个线程安全的 HashMap 实现类。它内部采用分段锁技术,实现了高并发下的性能优化。ConcurrentHashMap 的主要特点如下:
  • • 锁分段:ConcurrentHashMap 将整个哈希表分成多个段,每个段独立加锁。这样,多个线程可以同时访问不同的段,提高了并发性能。
  • • 读写锁:ConcurrentHashMap 的读写锁可以根据操作类型自动切换,降低了锁的竞争程度。
  • • 空键(null key)和空值(null value)处理:ConcurrentHashMap 可以存储空键和空值。

2. 线程不安全的类:HashMap HashMap 是 Java 提供的一个非线程安全的 HashMap 实现类。在多线程环境下,多个线程同时访问 HashMap 可能导致数据不一致。以下是线程不安全的示例代码:

public class HashMapDemo {public static void main(String[] args) {Map<String, Integer> map = new HashMap<>();map.put("a", 1);map.put("b", 2);Thread t1 = new Thread(() -> {map.put("a", 3);});Thread t2 = new Thread(() -> {map.put("b", 4);});t1.start();t2.start();try {t1.join();t2.join();} catch (InterruptedException e) {e.printStackTrace();}System.out.println(map.get("a")); // 输出 3System.out.println(map.get("b")); // 输出 4}
}

二、List

1. 线程安全的类:CopyOnWriteArrayList CopyOnWriteArrayList 是 Java 提供的一个线程安全的 ArrayList 实现类。它通过在写操作时创建底层数组的新副本,实现了线程安全。CopyOnWriteArrayList 的主要特点如下:

  • • 写入时复制:当向 CopyOnWriteArrayList 添加元素时,不直接修改当前数组,而是创建一个新的数组,将原数组的元素复制到新数组,然后引用新数组。这样,多个线程可以同时读取同一个数组,提高了并发性能。
  • • 读取无锁:由于多个线程共享同一个数组,CopyOnWriteArrayList 在读取操作时不需要加锁。
    2. 线程不安全的类:ArrayList ArrayList 是 Java 提供的一个非线程安全的 ArrayList 实现类。在多线程环境下,多个线程同时访问 ArrayList 可能导致数据不一致。以下是线程不安全的示例代码:
public class ArrayListDemo {public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("a");list.add("b");Thread t1 = new Thread(() -> {list.add("c");});Thread t2 = new Thread(() -> {list.add("d");});t1.start();t2.start();try {t1.join();t2.join();} catch (InterruptedException e) {e.printStackTrace();}System.out.println(list.size()); // 输出 4}
}

三、Set

  1. 线程安全的类:CopyOnWriteArraySet CopyOnWriteArraySet 是 Java 提供的一个线程安全的 HashSet 实现类。它内部使用 CopyOnWriteArrayList 实现,通过在写操作时创建底层数组的新副本,实现了线程安全。
    2. 线程不安全的类:HashSet HashSet 是 Java 提供的一个非线程安全的 HashSet 实现类。在多线程环境下,多个线程同时访问 HashSet 可能导致数据不一致。以下是线程不安全的示例代码:
public class HashSetDemo {public static void main(String[] args) {Set<String> set = new HashSet<>();set.add("a");set.add("b");Thread t1 = new Thread(() -> {set.add("c");});Thread t2 = new Thread(() -> {set.add("d");});t1.start();t2.start();try {t1.join();t2.join();} catch (InterruptedException e) {e.printStackTrace();}System.out.println(set.size()); // 输出 4}
}

总结 本文介绍了 Map、List、Set 三个集合类型的线程安全类和线程不安全的类,并给出了示例代码。在多线程环境下,建议使用线程安全的集合类,如 ConcurrentHashMap、CopyOnWrite

今天的分享就到这里,如果觉得对你有帮助,感谢点赞、分享、关注一波,你的认可是我创造的最大动力。

更多内容请关注公众号:程序猿漠然,一个分享有趣后端知识的公众号。

这篇关于Map、List、Set 分别说下线程安全类和线程不安全的类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/510558

相关文章

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

客户案例:安全海外中继助力知名家电企业化解海外通邮困境

1、客户背景 广东格兰仕集团有限公司(以下简称“格兰仕”),成立于1978年,是中国家电行业的领军企业之一。作为全球最大的微波炉生产基地,格兰仕拥有多项国际领先的家电制造技术,连续多年位列中国家电出口前列。格兰仕不仅注重业务的全球拓展,更重视业务流程的高效与顺畅,以确保在国际舞台上的竞争力。 2、需求痛点 随着格兰仕全球化战略的深入实施,其海外业务快速增长,电子邮件成为了关键的沟通工具。

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

poj 3050 dfs + set的妙用

题意: 给一个5x5的矩阵,求由多少个由连续6个元素组成的不一样的字符的个数。 解析: dfs + set去重搞定。 代码: #include <iostream>#include <cstdio>#include <set>#include <cstdlib>#include <algorithm>#include <cstring>#include <cm

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

Collection List Set Map的区别和联系

Collection List Set Map的区别和联系 这些都代表了Java中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。 有序否 允许元素重复否 Collection 否 是 List 是 是 Set AbstractSet 否

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟