0

0

什么是Java中的分段锁思想_ConcurrentHashMap从1.7到1.8的演进

P粉602998670

P粉602998670

发布时间:2026-02-11 10:43:02

|

594人浏览过

|

来源于php中文网

原创

ConcurrentHashMap 1.7 通过 Segment 数组实现分段锁,每个 Segment 是独立的 ReentrantLock + 小型哈希表,put 仅锁定对应 Segment,get 完全无锁;但存在哈希倾斜退化、size() 阻塞等问题,故 1.8 改用 CAS + synchronized 锁单个 Node 并引入树化优化。

什么是java中的分段锁思想_concurrenthashmap从1.7到1.8的演进

分段锁在ConcurrentHashMap 1.7里怎么实现的

ConcurrentHashMap 1.7 的分段锁本质是把整个哈希表切成了 Segment 数组,每个 Segment 是一个独立的 ReentrantLock + 小型哈希表。写操作(如 put)只锁住对应 key 落入的那个 Segment,其他段还能并发读写。

常见错误现象:以为“分段”能彻底避免锁竞争——其实如果大量 key 哈希后落在同一个 Segment(比如自定义 hashCode 返回固定值),那它就退化成单点瓶颈,吞吐不升反降。

实操建议:

Hypotenuse AI
Hypotenuse AI

AI写作助手和文本生成器,根据关键词生成原创的、有洞察力的文章

下载
  • concurrencyLevel 参数只是初始化 Segment 数组长度的提示值,不是硬上限;实际段数会取大于等于该值的最小 2 的幂(如传 10 → 实际用 16 段)
  • 每个 Segment 内部仍是数组 + 链表,扩容时只扩本段,但 size() 需要尝试加锁所有段来累加,可能阻塞较久
  • JDK 1.7 的 get() 完全无锁,靠 volatile 变量和不可变节点保证可见性——这点常被误认为“读也加锁”,其实不是

为什么 1.8 彻底干掉了 Segment

因为 Segment 带来额外内存开销(每个段都有一套 table、count、modCount 等字段),且无法解决单个桶(bin)的并发冲突——只要两个线程往同一个链表头插入,还是得串行。

立即学习Java免费学习笔记(深入)”;

1.8 改用“CAS + synchronized 锁单个 Node”:数组元素(Node)本身作为锁粒度,配合 TreeBin 在链表过长时转红黑树,进一步降低哈希碰撞下的查找/插入成本。

实操建议:

  • 1.8 的 put() 先无锁 CAS 插入头节点,失败才用 synchronized (f) 锁住该桶的首节点(f),不是锁整个 table
  • 扩容(transfer)变成协作式迁移:多个线程可同时参与搬数据,每个线程负责一段 table 区间,通过 stride 控制粒度
  • 注意 computeIfAbsent 这类方法在 1.8 中可能触发树化或扩容,若 lambda 里有阻塞操作,会卡住整个桶,影响其他线程对该桶的操作

从 1.7 升级到 1.8 后哪些行为变了

最易踩坑的是迭代器语义和 size() 行为差异:1.7 的 keySet().iterator() 是弱一致性(weakly consistent),允许遍历时修改;1.8 的迭代器仍弱一致,但内部结构变化更频繁(树/链表切换、扩容中迁移),导致某些遍历结果更“跳跃”。

性能上,1.8 在高并发写+低哈希碰撞场景下优势明显;但若写操作极少、读极多,1.7 的无锁 get() 和更简单的结构反而更轻量。

实操建议:

  • size() 在 1.7 中需加锁统计所有 Segment,可能慢;1.8 改用 baseCount + CounterCell[] 的 CAS 累加,但仍是近似值——严格计数请改用 mappingCount()
  • 1.8 不再支持 rehash 相关监控(如 segments 字段已不存在),依赖反射或 JMX 查看内部状态的代码会直接失败
  • 自定义 Comparator 用于树化时,必须满足与 equals() 一致的逻辑,否则 containsKey 可能返回 false(即使 key 存在)

现在还该手动分段锁吗

几乎不该。除非你在 JDK 1.7 环境下维护老系统,或者面对的是极特殊场景:比如某个业务 key 天然聚合成几十个大组,每组内操作高度隔离,且你愿意承担自己实现锁分片、负载均衡、扩容协调的复杂度。

现实中,JDK 1.8 的 ConcurrentHashMap 已经把锁粒度压到单个桶,配合 CAS 和树化,对绝大多数场景足够。手动分段反而容易引入死锁(比如跨段操作没按固定顺序加锁)、状态不一致(段间计数不同步)等问题。

真正要注意的其实是:别把 ConcurrentHashMap 当作通用线程安全容器去塞各种复杂对象——它的线程安全只保障自身结构变更,value 对象内部状态是否线程安全,它不管。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

198

2023.11.20

c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

69

2025.10.23

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

211

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

191

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

58

2026.01.05

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

653

2023.08.10

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

67

2026.02.11

Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析
Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析

本专题全面整理了Yandex搜索引擎的官方入口信息,涵盖国际版与俄罗斯版官网访问方式、网页版直达入口及免登录使用说明,帮助用户快速、安全地进入Yandex官网,高效使用其搜索与相关服务。

179

2026.02.11

虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法
虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法

本专题系统整理了虫虫漫画官网及网页版最新入口,涵盖免登录观看、正版漫画全集在线阅读方式,并汇总稳定可用的访问渠道,帮助用户快速找到虫虫漫画官方页面,轻松在线阅读各类热门漫画内容。

38

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.5万人学习

C# 教程
C# 教程

共94课时 | 9.2万人学习

Java 教程
Java 教程

共578课时 | 63.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号