Java基础知识总结(82)

ConcurrentHashMap
JDK 1.7中的ConcurrentHashMap
原理:

JDK 1.7的ConcurrentHashMap的锁机制基于粒度更小的分段锁,分段锁其实是一种锁的设计,并不是具体的一种锁,对于ConcurrentHashMap而言,分段锁技术将Key分成一个一个小Segment存储,然后给每一段数据配一把锁,当一个线程占用锁访问其中一段数据的时候,其他段的数据也能被其他线程访问,能够实现真正的并发访问。

内部结构:

1.HashEntry HashEntry结构用于存储"Key-Value对"(即"键-值对")数据,以及存储其后继节点的指针。 2.Segment ConcurrentHashMap中的一个段称为Segment,Segment继承了ReentrantLock,所以一个段又是一个ReentrantLock。Segment内部拥有一个HashEntry数组类型的成员table,数组中的每个元素又是一个链表,这个由HashEntry链接起来的链表对应一个哈希表的桶,也就是说,table的一个元素对应哈希表的一个桶。 3.ConcurrentHashMap ConcurrentHashMap在默认并发级别会创建包含16个Segment对象的数组,每个Segment大约守护整个哈希表中桶总数的1/16,其中第N个哈希桶由第N mod 16个锁来保护。

缺点:

1、锁粒度太大

2、由于自身数据结构的原因,添加元素时需要定位两次

3、可能会导致链表过长从而导致查询效率低

JDK 1.8中的ConcurrentHashMap
结构:

JDK 1.8中ConcurrentHashMap的内部结构采用数组+链表或红黑树来实现,引入了红黑树的结构,当桶的节点数超过一定的阈值(默认为64)时,JDK 1.8将链表结构自动转换成红黑树的结构,可以理解为将链式桶转换成树状桶。 ConcurrentHashMap的内部结构的层次关系为ConcurrentHashMap→链式桶/树状桶。每次访问的时候只需对一个桶进行锁定,而不需要将整个Map集合都进行粗粒度的锁定。

相关推荐
一晌小贪欢21 小时前
Python-12 Python生成器与yield:惰性求值的艺术
开发语言·python·python基础·python3·python小白·python生成器
wearegogog12321 小时前
使用MATLAB实现平方倍频法对DSSS/BPSK信号进行载频估计
开发语言·matlab
小二·21 小时前
Spring框架入门:代理模式详解
java·spring·代理模式
Rock_yzh21 小时前
LeetCode算法刷题——53. 最大子数组和
java·数据结构·c++·算法·leetcode·职场和发展·动态规划
简单的话*21 小时前
Logback 日志按月归档并保留 180 天,超期自动清理的配置实践
java·前端·python
m***567221 小时前
在Nginx上配置并开启WebDAV服务的完整指南
java·运维·nginx
蓝眸少年CY21 小时前
Python科学计算 Numpy库
开发语言·python·numpy
困惑阿三21 小时前
深入理解 JavaScript 中的(Promise.race)
开发语言·前端·javascript·ecmascript·reactjs
我命由我1234521 小时前
微信小程序 bind:tap 与 bindtap 的区别
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
Mr.朱鹏21 小时前
RocketMQ可视化监控与管理
java·spring boot·spring·spring cloud·maven·intellij-idea·rocketmq