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

ConcurrentHashMap讲解

在 Java 并发编程中ConcurrentHashMap是高频使用的线程安全 Map 实现也是面试中几乎必问的核心知识点。它完美解决了 HashMap 线程不安全、Hashtable 性能极差的痛点在高并发场景下实现了安全与性能的平衡。本文将从设计背景、JDK1.7/JDK1.8 底层实现、核心方法、扩容机制到面试高频考点一站式讲透 ConcurrentHashMap帮你轻松应对面试与实际开发。一、为什么需要 ConcurrentHashMap在多线程环境下我们常用的 Map 实现各有缺陷HashMap线程不安全JDK1.7 扩容会出现链表成环死循环多线程 put 会导致数据覆盖、丢失绝对不能用于并发场景。Hashtable通过给整个方法加synchronized全局锁保证安全但所有线程竞争同一把锁并发吞吐量极低性能拉胯。而 ConcurrentHashMap 的设计目标就是保证线程安全的同时最大化提升并发吞吐量是高并发场景下的首选 Map 实现。二、底层实现JDK1.7 与 JDK1.8 核心对比ConcurrentHashMap 在 JDK1.8 经历了颠覆性重构从分段锁升级为 CAS 细粒度锁结构与性能全面优化这也是面试最核心的考点。2.1 JDK1.7分段锁Segment HashEntry 链表核心结构采用Segment 数组 HashEntry 数组 链表的双层数组结构Segment 继承自ReentrantLock可重入锁每个 Segment 独立管理一段哈希表。线程安全机制分段锁锁粒度为Segment 分段不同分段的操作互不干扰只有同一分段才会竞争锁。默认 16 个 Segment最大并发度为 16相比 Hashtable 全局锁并发性能大幅提升。get 操作无锁通过volatile修饰 value 保证可见性直接遍历链表取值。缺陷锁粒度仍偏粗同一 Segment 下多线程会阻塞双层数组结构复杂维护成本高仅支持单个 Segment 独立扩容整体效率低。2.2 JDK1.8CAS synchronized桶级锁核心结构抛弃 Segment采用与 HashMap1.8 一致的Node 数组 链表 红黑树结构更简洁。Node 节点的 value、next 指针用volatile修饰保证多线程可见性与有序性链表长度≥8 且数组长度≥64 时转为红黑树查询复杂度从 O (n) 降为 O (logn)新增ForwardingNode扩容标记节点引导线程访问新数组。线程安全机制面试必背桶为空时通过CAS 无锁插入节点避免锁开销桶不为空时对桶头节点加 synchronized 锁锁粒度细化到单个桶结合 volatile 保证数据可见性杜绝指令重排序问题。JDK1.8 核心优化锁粒度从分段升级为桶并发度理论无上限移除 Segment 层结构简化查询与扩容效率更高支持多线程并发扩容解决单线程扩容瓶颈红黑树优化长链表查询性能适配大数据量场景。三、核心方法原理面试高频追问3.1 put 方法JDK1.8计算 key 哈希值二次散列减少冲突CAS 初始化 Node 数组未初始化时定位桶下标桶空则 CAS 插入节点失败自旋重试桶非空则锁住头节点遍历链表 / 红黑树key 存在则替换 value不存在则尾插插入后判断链表长度达标则转红黑树检查元素数量达到阈值触发扩容。3.2 get 方法无锁设计计算哈希定位桶下标头节点为空直接返回 null遍历链表 / 红黑树匹配 key返回 volatile 修饰的 value。面试考点get 全程无锁依赖 volatile 保证可见性节点结构稳定无需加锁性能与 HashMap 持平。3.3 size 方法JDK1.7遍历所有 Segment 并加全局锁效率低JDK1.8通过baseCountcounterCells分散计数CAS 重试累加避免全局锁允许短暂计数偏差最终保证准确。四、扩容机制多线程协同扩容扩容触发条件元素数量达到数组长度 × 0.75负载因子且为链表节点时触发扩容后数组长度变为原来 2 倍保持 2 的幂。JDK1.8 并发扩容逻辑创建新的 2 倍容量 Node 数组通过transferIndex标记迁移范围多线程 CAS 领取迁移任务对原桶加锁将节点迁移到新数组对应位置迁移完成后原桶标记为ForwardingNode引导线程访问新数组全桶迁移完毕替换为新数组扩容结束。核心优势多线程协同迁移无死循环风险解决了 HashMap 单线程扩容的性能瓶颈。五、面试高频考点汇总直接背诵5.1 三大 Map 核心对比对比维度HashMapHashtableConcurrentHashMapJDK1.8线程安全不安全安全全局锁安全CAS 桶级锁并发性能高极低高底层结构数组 链表 红黑树数组 链表数组 链表 红黑树null 键值支持不支持不支持扩容单线程易死循环单线程多线程并发扩容5.2 必问原理题JDK1.8 如何保证线程安全桶空用 CAS 无锁插入桶非空锁住头节点volatile 保证可见性扩容用 ForwardingNode 避免冲突。为什么取消分段锁分段锁粒度粗同一 Segment 并发阻塞CAS 成熟后桶级锁更细性能更优结构也更简洁。为什么不支持 null 键 / 值多线程下 get 返回 null 无法区分 “key 不存在” 和 “value 为 null”containsKey与get存在并发修改风险直接禁止更安全。get 为什么无锁value 用 volatile 修饰保证可见性链表仅尾插 / 删除结构稳定无需加锁即可安全读取。5.3 场景选型单线程优先 HashMap性能最高多线程必选 ConcurrentHashMap兼顾安全与性能Hashtable仅遗留项目维护新代码禁止使用。六、总结ConcurrentHashMap 是 Java 并发集合的巅峰设计之一核心思路是用细粒度并发控制替代全局锁JDK1.7 靠分段锁实现基础并发安全JDK1.8 升级为 CAS synchronized 桶级锁搭配红黑树与并发扩容成为高并发首选。

相关文章:

ConcurrentHashMap讲解

在 Java 并发编程中,ConcurrentHashMap 是高频使用的线程安全 Map 实现,也是面试中几乎必问的核心知识点。它完美解决了 HashMap 线程不安全、Hashtable 性能极差的痛点,在高并发场景下实现了安全与性能的平衡。本文将从设计背景、JDK1.7/JDK…...

解锁毕业论文新姿势:书匠策AI,你的学术超级英雄!

在学术征途上,每一位即将毕业的大学生都怀揣着梦想与挑战,而毕业论文则是那座必须跨越的巍峨大山。面对这座大山,你是否曾感到迷茫、无助,甚至有些力不从心?别怕,今天,就让我带你认识一位学术界…...

Electron应用自动更新全解析:如何用electron-updater搭建私有更新服务器(附Vue2示例)

Electron应用私有化自动更新体系构建指南 当你的Electron应用从开发阶段进入生产环境,如何确保用户始终使用最新版本?本文将带你从零构建一套企业级私有更新体系,涵盖服务端部署策略、客户端配置优化以及用户体验设计三大核心模块。 1. 更新服…...

解锁论文新姿势:书匠策AI,你的毕业论文“智能加速器”!

在学术的征途上,毕业论文无疑是每位学子必须跨越的一道重要关卡。它不仅是对你大学四年学习成果的全面检验,更是你迈向学术殿堂或职场的重要敲门砖。然而,面对堆积如山的资料、错综复杂的逻辑结构以及繁琐的格式要求,许多学子往往…...

终极Modbus测试工具:OpenModScan让工业通讯调试变得前所未有的简单

终极Modbus测试工具:OpenModScan让工业通讯调试变得前所未有的简单 【免费下载链接】OpenModScan Open ModScan is a Free Modbus Master (Client) Utility 项目地址: https://gitcode.com/gh_mirrors/op/OpenModScan 在工业自动化领域,Modbus协议…...

别再傻傻分不清!STM32定时器里Prescaler和ClockDivision到底谁管心跳谁管滤波?

STM32定时器双频分频机制深度解析:从心跳节拍到信号滤波 第一次接触STM32定时器配置时,看到Prescaler和ClockDivision这两个参数,很多开发者都会产生疑惑——它们看起来都是在做"分频"这件事,为什么需要两个参数&#x…...

告别预编译固件:手把手教你从零构建Pico PC RK3588S的Ubuntu 20.04根文件系统

深度定制RK3588S开发板:从零构建Ubuntu 20.04根文件系统的完整指南 当拿到一块全新的Pico PC RK3588S开发板时,许多开发者会发现厂商仅提供了预编译的固件包。这种"黑盒"模式虽然能快速启动设备,却严重限制了系统级定制的可能性。…...

Anaconda3重装避雷指南:Win11系统这些配置不删干净等于白装(2024实测)

Anaconda3重装避雷指南:Win11系统深度清理实战手册 为什么你的Anaconda重装总失败? 每次重装Anaconda后,那些熟悉的报错信息又阴魂不散地出现?"明明已经卸载干净了"——这是大多数数据科学从业者最常发出的困惑。实际上…...

国金证券QMT实盘连接指南:手把手教你配置交易环境与策略回测

国金证券QMT实盘连接实战:从环境搭建到策略部署全解析 引言 在量化交易的世界里,工具的选择往往决定了策略执行的效率与稳定性。国金证券QMT作为国内主流的量化交易平台之一,以其稳定的实盘连接能力和丰富的API接口受到众多量化交易者的青睐。…...

NMPC轨迹跟踪:从非线性模型构建到Simulink闭环仿真

1. 非线性模型预测控制(NMPC)基础入门 第一次接触NMPC时,我也被那些数学公式吓到了。但后来发现,它其实就是个"会看地图的老司机"——通过预测未来几步的路况,提前调整方向盘。与传统的MPC相比,N…...

告别内存焦虑:用DiskANN在单机上搞定十亿向量检索的完整配置与调优指南

告别内存焦虑:用DiskANN在单机上搞定十亿向量检索的完整配置与调优指南 当你的推荐系统需要处理超过1亿条商品特征向量,或是生物医药团队要匹配数十亿分子结构时,传统内存索引方案会让服务器内存条价格直接突破年度预算。这时DiskANN就像一位…...

避坑指南:CentOS7部署LibreNMS常见错误及解决方案

CentOS7部署LibreNMS避坑实战:从SELinux到数据库权限的深度排错指南 对于网络监控系统的部署,LibreNMS以其开源特性和强大功能成为众多技术团队的首选。但在CentOS7环境下,从系统配置到服务调优的每个环节都可能成为阻碍顺利部署的暗礁。本文…...

实测对比:openEuler三大桌面环境UKUI/DDE/XFCE安装体验与性能消耗

实测对比:openEuler三大桌面环境UKUI/DDE/XFCE安装体验与性能消耗 当技术决策者面对openEuler操作系统时,桌面环境的选择往往成为影响工作效率的关键因素。本文将基于openEuler 24.03 LTS环境,深度实测UKUI、DDE和XFCE三大主流桌面环境&…...

DecepGPT Schema-Driven Deception Detection with Multicultural Datasets and Robust Multimodal Learnin

DecepGPT: Schema-Driven Deception Detection with Multicultural Datasets and Robust Multimodal Learning Authors: Jiajian Huang, Dongliang Zhu, Zitong YU, Hui Ma, Jiayu Zhang, Chunmei Zhu, Xiaochun Cao Deep-Dive Summary: DeepGPT: 基于模式驱动的多文化数据集…...

EcomGPT-中英文-7B电商模型与数据库课程设计:构建智能电商问答知识库

EcomGPT-中英文-7B电商模型与数据库课程设计:构建智能电商问答知识库 电商平台每天要处理海量的用户咨询:“这件衣服有M码吗?”、“这个手机和昨天看的那个有什么区别?”、“帮我推荐几款适合送长辈的茶叶”。传统客服要么忙不过…...

手把手教你用PasteMD:本地AI一键整理笔记和代码片段

手把手教你用PasteMD:本地AI一键整理笔记和代码片段 你是不是也经常被这些场景困扰?开会时用手机快速记下的要点,事后整理时发现全是碎片化的短句,毫无结构可言;从网页复制下来的技术文档,格式混乱&#x…...

开源像素艺术生成器落地实操:像素幻梦在独立游戏开发中的应用

开源像素艺术生成器落地实操:像素幻梦在独立游戏开发中的应用 1. 像素幻梦工具介绍 Pixel Dream Workshop(像素幻梦创意工坊)是一款基于FLUX.1-dev扩散模型的下一代像素艺术生成工具。与传统的AI绘图工具不同,它采用了明亮的16-…...

不止于步骤:用SPM预处理fMRI数据时,那些没人告诉你的‘隐藏’技巧与效率工具

不止于步骤:用SPM预处理fMRI数据时,那些没人告诉你的‘隐藏’技巧与效率工具 当你面对上百个被试的fMRI数据时,是否曾为重复点击SPM的GUI界面而感到疲惫?是否担心手动操作带来的潜在错误?本文将带你超越基础教程&#…...

大疆L1点云数据导出后,用CloudCompare做可视化与简单分析的完整流程

大疆L1点云数据从导出到分析:CloudCompare实战全流程指南 当你从DJI Terra中导出L1激光雷达的LAS文件时,真正的数据价值挖掘才刚刚开始。作为测绘工程师或三维建模从业者,如何将这些原始点云转化为可操作的洞察?本文将带你用开源神…...

Python办公自动化:用PyMuPDF+pdfplumber一键提取PDF文字/图片/表格(附完整代码)

Python办公自动化实战:PyMuPDF与pdfplumber高效提取PDF三要素 每天面对堆积如山的PDF文档,行政和财务人员最头疼的莫过于手动复制粘贴文字、截图保存图片、重新绘制表格。我曾见过一位财务同事为了处理200份供应商报价单,连续加班一周手工录入…...

Vue-Vben-Admin主题定制实战指南:从原理到实现的深度探索

Vue-Vben-Admin主题定制实战指南:从原理到实现的深度探索 【免费下载链接】vue-vben-admin vbenjs/vue-vben-admin: 是一个基于 Vue.js 和 Element UI 的后台管理系统,支持多种数据源和插件扩展。该项目提供了一个完整的后台管理系统,可以方便…...

Grok-1深度实战指南:3140亿参数混合专家模型的高级部署与优化

Grok-1深度实战指南:3140亿参数混合专家模型的高级部署与优化 【免费下载链接】grok-1 马斯克旗下xAI组织开源的Grok AI项目的代码仓库镜像,此次开源的Grok-1是一个3140亿参数的混合专家模型 项目地址: https://gitcode.com/GitHub_Trending/gr/grok-1…...

nli-distilroberta-base效果展示:Contradiction类样本的Attention权重可视化分析

nli-distilroberta-base效果展示:Contradiction类样本的Attention权重可视化分析 1. 项目概述 nli-distilroberta-base是基于DistilRoBERTa模型的自然语言推理(NLI)服务,专门用于分析句子对之间的逻辑关系。这个轻量级模型能够高效判断两个句子之间的三…...

利用Charles实现请求与响应的动态修改:从基础到实战

1. Charles工具简介与基础配置 Charles是一款功能强大的网络抓包工具,它就像是你手机和电脑之间的"透明玻璃",能让你清清楚楚地看到所有进出的网络请求。我第一次接触Charles是在调试一个电商APP的支付接口时,当时遇到一个诡异的bu…...

别再死记硬背了!用Treap(树堆)搞定LeetCode平衡树难题,附C++完整模板

Treap实战指南:用随机化平衡树高效解决LeetCode难题 1. 为什么选择Treap而非传统平衡树? 在算法竞赛和面试场景中,我们经常需要处理动态有序集合的操作。传统平衡树如AVL和红黑树虽然能保证严格的平衡性,但它们的实现复杂度往往让…...

Element React:革新性UI组件库助力React开发者高效构建企业级应用界面

Element React:革新性UI组件库助力React开发者高效构建企业级应用界面 【免费下载链接】element-react Element UI 项目地址: https://gitcode.com/gh_mirrors/el/element-react 在现代Web应用开发中,界面构建往往占据了开发者大量时间与精力。El…...

Hypervisor环境下高效进程间通信技术解析

1. Hypervisor环境下的进程通信挑战 在虚拟化技术大行其道的今天,Hypervisor环境下的进程间通信(IPC)已经成为系统性能的关键瓶颈。想象一下,你住在小区同一栋楼的两个单元里,明明直线距离只有10米,却要绕到…...

LeetCode 53. 最大子数组和 超详细题解(贪心+分治+动规)

LeetCode 53. 最大子数组和 超详细题解(贪心分治动规) 🏷️ 标签:动态规划、贪心算法、分治法、数组、经典面试题 📊 难度:简单 | 📝 题目编号:53 | 🗂️ 题型&#xff1…...

Unsloth让AI触手可及:免费GPU+开源框架,训练自己的模型

Unsloth让AI触手可及:免费GPU开源框架,训练自己的模型 1. Unsloth简介:高效微调的开源利器 Unsloth是一个专为大型语言模型(LLM)优化的开源微调框架,它的核心使命是让AI训练变得高效且易于获取。通过创新的技术手段,…...

线上年销 10 亿的背后:实体转型的 “线上 + 线下” 实战逻辑复盘

在行业的讨论声中,总有声音将某些日化品牌的崛起归类为 “资本运作” 或 “流量套路”。但实际上,深耕日化赛道近 20 年的顶俏,凭借 10 亿级的年销售额,为无数身处转型期的实体商家,提供了一份极具含金量的实战答卷。从…...