【亮剑】Java中的并发容器ConcurrentHashMap,它在JDK1.5中引入,用于替换HashTable和SynchronizedMap

简介: 【4月更文挑战第30天】本文介绍了Java中的并发容器ConcurrentHashMap,它在JDK1.5中引入,用于替换HashTable和SynchronizedMap。文章展示了创建、添加、获取、删除和遍历元素的基本用法。ConcurrentHashMap的内部实现基于分段锁,每个段是一个独立的Hash表,通过分段锁实现并发控制。每个段内部采用数组+链表/红黑树的数据结构,当冲突过多时转为红黑树优化查询。此外,它有扩容机制,当元素超过阈值时,会逐段扩容并翻倍Segment数量,以保持高性能的并发访问。

一、引言

在多线程环境下,为了保证数据的一致性和并发性能,我们通常会使用到并发容器。而在Java中,ConcurrentHashMap就是一种非常常用的并发容器。它是JDK1.5中引入的,用于替代HashTable和SynchronizedMap等同步容器,提供了更好的并发性能。本文将详细介绍ConcurrentHashMap的使用方法及其内部实现原理。

二、ConcurrentHashMap的使用方法

  1. 创建ConcurrentHashMap对象
import java.util.concurrent.ConcurrentHashMap;

public class ConcurrentHashMapDemo {
   
    public static void main(String[] args) {
   
        ConcurrentHashMap<String, Integer> concurrentHashMap = new ConcurrentHashMap<>();
    }
}
  1. 添加元素
import java.util.concurrent.ConcurrentHashMap;

public class ConcurrentHashMapDemo {
   
    public static void main(String[] args) {
   
        ConcurrentHashMap<String, Integer> concurrentHashMap = new ConcurrentHashMap<>();
        concurrentHashMap.put("one", 1);
        concurrentHashMap.put("two", 2);
        concurrentHashMap.put("three", 3);
    }
}
  1. 获取元素
import java.util.concurrent.ConcurrentHashMap;

public class ConcurrentHashMapDemo {
   
    public static void main(String[] args) {
   
        ConcurrentHashMap<String, Integer> concurrentHashMap = new ConcurrentHashMap<>();
        concurrentHashMap.put("one", 1);
        concurrentHashMap.put("two", 2);
        concurrentHashMap.put("three", 3);

        Integer one = concurrentHashMap.get("one");
        System.out.println("one: " + one);
    }
}
  1. 删除元素
import java.util.concurrent.ConcurrentHashMap;

public class ConcurrentHashMapDemo {
   
    public static void main(String[] args) {
   
        ConcurrentHashMap<String, Integer> concurrentHashMap = new ConcurrentHashMap<>();
        concurrentHashMap.put("one", 1);
        concurrentHashMap.put("two", 2);
        concurrentHashMap.put("three", 3);

        concurrentHashMap.remove("one");
    }
}
  1. 遍历元素
import java.util.concurrent.ConcurrentHashMap;

public class ConcurrentHashMapDemo {
   
    public static void main(String[] args) {
   
        ConcurrentHashMap<String, Integer> concurrentHashMap = new ConcurrentHashMap<>();
        concurrentHashMap.put("one", 1);
        concurrentHashMap.put("two", 2);
        concurrentHashMap.put("three", 3);

        for (String key : concurrentHashMap.keySet()) {
   
            System.out.println("Key: " + key + ", Value: " + concurrentHashMap.get(key));
        }
    }
}

三、ConcurrentHashMap的内部实现原理

  1. 分段锁(Segment)

ConcurrentHashMap的核心思想是将整个Map分为N个Segment,每个Segment独立维护一部分数据。这样在进行put、remove等操作时,只需要锁定当前Segment,而不需要锁定整个Map,从而提高并发性能。默认情况下,ConcurrentHashMap会创建16个Segment。

  1. 数据结构

每个Segment内部使用了一个数组来存储键值对,数组的索引通过hashCode计算得到。当发生哈希冲突时,会使用链表或红黑树来解决。当链表长度超过一定阈值时,会转换为红黑树以提高查询效率。

  1. 扩容机制

当某个Segment的元素个数超过阈值时,会触发扩容操作。扩容时,会创建一个新的数组,并将旧数组的数据迁移到新数组中。同时,Segment的数量也会翻倍。为了减少锁的粒度,ConcurrentHashMap采用了逐段扩容的策略,每次只扩容一个Segment。

四、总结

本文详细介绍了ConcurrentHashMap的使用方法及其内部实现原理。通过分段锁的设计,ConcurrentHashMap在保证数据一致性的同时,提供了较好的并发性能。在实际应用中,我们可以根据需要选择合适的并发容器,以提高系统的性能。

相关文章
|
7月前
|
Java 虚拟化 容器
(Java)Java里JFrame窗体的基本操作(容器布局篇-1)
容器 容器,我的理解是可以包容其他东西的玩意。它可以是一个盒子,可以是一个虚拟化的物品,可只要能包裹住其他存在质体的东西,那么都可以称作是容器。例如:JPanel组件和JScollPane组件两者都是容器也是组件。 既然有容器,那么容器中的布局就必不可少了。不然不规矩的摆放物品,人类看不习惯,我也看不习惯 ???? 本篇内容,将说明java JFrame窗体里容器中几类布局。 说明:所有在JFrame窗体里的容器布局都会使用setLayout()方法,采用的布局参数都将放进这个方法里 绝对布局 调用窗体容器
218 1
|
11月前
|
存储 缓存 安全
Java 集合容器常见面试题及详细解析
本文全面解析Java集合框架,涵盖基础概念、常见接口与类的特点及区别、底层数据结构、线程安全等内容。通过实例讲解List(如ArrayList、LinkedList)、Set(如HashSet、TreeSet)、Map(如HashMap、TreeMap)等核心组件,帮助读者深入理解集合容器的使用场景与性能优化。适合准备面试或提升开发技能的开发者阅读。
209 0
|
Java
【源码】【Java并发】【ConcurrentHashMap】适合中学体质的ConcurrentHashMap
本文深入解析了ConcurrentHashMap的实现原理,涵盖JDK 7与JDK 8的区别、静态代码块、构造方法、put/get/remove核心方法等。JDK 8通过Node数组+链表/红黑树结构优化并发性能,采用CAS和synchronized实现高效锁机制。文章还详细讲解了hash计算、表初始化、扩容协助及计数更新等关键环节,帮助读者全面掌握ConcurrentHashMap的工作机制。
340 6
【源码】【Java并发】【ConcurrentHashMap】适合中学体质的ConcurrentHashMap
|
缓存 安全 Java
【Java并发】【ConcurrentHashMap】适合初学体质的ConcurrentHashMap入门
ConcurrentHashMap是Java中线程安全的哈希表实现,支持高并发读写操作。相比Hashtable,它通过分段锁(JDK1.7)或CAS+synchronized(JDK1.8)实现更细粒度锁控制,提升性能与安全性。本文详细介绍其构造方法、添加/获取/删除元素等常用操作,并对比JDK1.7和1.8的区别,帮助开发者深入理解与使用ConcurrentHashMap。欢迎关注,了解更多!
1042 5
【Java并发】【ConcurrentHashMap】适合初学体质的ConcurrentHashMap入门
|
11月前
|
缓存 Java API
Java 集合容器实操技巧与案例详解
本教程基于Java 8+新特性和现代开发实践,深入讲解Java集合容器的实操技巧。通过具体场景演示Stream API数据处理、ConcurrentHashMap并发控制、LinkedHashMap实现LRU缓存、TreeSet自定义排序等高级特性。同时涵盖computeIfAbsent优化操作、EnumMap专用集合使用、集合统计与运算(交集、并集、差集)等内容。代码示例丰富,助力掌握高效编程方法。[点击获取完整代码](https://pan.quark.cn/s/14fcf913bae6)。
259 0
|
存储 安全 算法
Java容器及其常用方法汇总
Java Collections框架提供了丰富的接口和实现类,用于管理和操作集合数据。
342 2
Java容器及其常用方法汇总
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
489 3
|
10月前
|
存储 Ubuntu 安全
在Ubuntu 16.04上安装openjdk-6/7/8-jdk的步骤
在整个安装过程中,你可能需要管理员权限,因此你可能要使用 `sudo` 来获取必要的权限。记得做完每一个步骤后,都要检查输出,以确保没有发生错误,并且每项操作都成功完成。如果在安装过程中遇到问题,查看 `/var/log/` 下的日志文件对于问题的解决可能是有帮助的。
658 21
|
10月前
|
IDE Ubuntu Java
在Ubuntu18.04安装兼容JDK 8的Eclipse集成开发环境的指南。
完成以上步骤后,您将在Ubuntu 18.04系统上成功安装并配置了Eclipse IDE,它将与JDK 8兼容,可以开始进行Java开发工作。如果遇到任何问题,请确保每一步骤都正确执行,并检查是否所有路径都与您的具体情况相匹配。
480 11

热门文章

最新文章