当前位置: 首页> 游戏> 游戏 > ConcurrentHashMap原理分析——Java全栈知识(47)

ConcurrentHashMap原理分析——Java全栈知识(47)

时间:2025/7/14 1:05:39来源:https://blog.csdn.net/dghehe/article/details/141951858 浏览次数:0次

ConcurrentHashMap 是一种线程安全的高效 Map 集合
底层数据结构:

  • JDK1.7底层采用分段的数组+链表实现
  • JDK1.8 采用的数据结构跟HashMap1.8的结构一样,数组+链表/红黑二叉树。

1、JDK1.7中 concurrentHashMap

数据结构

  • 提供了一个segment数组,在初始化ConcurrentHashMap 的时候可以指定数组的长度,默认是16,一旦初始化之后中间不可扩容
  • 在每个segment中都可以挂一个HashEntry数组,数组里面可以存储具体的元素,HashEntry数组是可以扩容的
  • 在HashEntry存储的数组中存储的元素,如果发生冲突,则可以挂单向链表

存储流程

  • 先去计算key的hash值,然后确定segment数组下标
  • 再通过hash值确定hashEntry数组中的下标存储数据
  • 在进行操作数据的之前,会先判断当前segment对应下标位置是否有线程进行操作,为了线程安全使用的是ReentrantLock进行加锁,如果获取锁是被会使用cas自旋锁进行尝试

2、JDK1.8中 concurrentHashMap

在JDK1.8中,放弃了Segment臃肿的设计,数据结构跟HashMap的数据结构是一样的:数组+红黑树+链表

采用 CAS + Synchronized来保证并发安全进行实现

  • CAS控制数组节点的添加
  • synchronized只锁定当前链表或红黑二叉树的首节点,只要hash不冲突,就不会产生并发的问题 , 效率得到提升

[!note]
CAS 保证添加节点时没有多线程冲突,synchronized 保证访问 map 时没有多线程冲突

很简单,cas 保证了当当前插槽没有头结点时,也就是没有数据时,有多个线程同时添加数据到当前插槽作为头结点的并发安全问题。简单来说就是保证了头结点的添加是原子性的。添加成功后,就会给头结点加 syn 锁,保证了后续节点的原子性

关键字:ConcurrentHashMap原理分析——Java全栈知识(47)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: