当前位置:首页 > 科技  > 软件

Java 7与 Java 8中ConcurrentHashMap的实现原理对比分析

来源: 责编: 时间:2023-10-10 18:31:04 355观看
导读ConcurrentHashMap是Java中线程安全的哈希表实现。ConcurrentHashMap的由来:Java 7和Java 8中ConcurrentHashMap的实现原理的简要解析:Java 7中的ConcurrentHashMap实现原理:分段锁(Segment-based Locking)Java 7中的Concu

X3I28资讯网——每日最新资讯28at.com

ConcurrentHashMap是Java中线程安全的哈希表实现。X3I28资讯网——每日最新资讯28at.com

ConcurrentHashMap的由来:X3I28资讯网——每日最新资讯28at.com

X3I28资讯网——每日最新资讯28at.com

X3I28资讯网——每日最新资讯28at.com

Java 7和Java 8中ConcurrentHashMap的实现原理的简要解析:X3I28资讯网——每日最新资讯28at.com

Java 7中的ConcurrentHashMap实现原理:X3I28资讯网——每日最新资讯28at.com

分段锁(Segment-based Locking)

  • Java 7中的ConcurrentHashMap采用分段锁的机制,将整个数据结构分割为多个段(Segment)。
  • 每个段维护一个自己的哈希表,具有自己的锁。
  • 每次对ConcurrentHashMap的操作只需要获取对应段的锁,不会锁住整个数据结构,从而提高并发性能。

HashEntry数组

  • ConcurrentHashMap内部使用HashEntry数组来存储键值对。
  • HashEntry是一个包含键、值和next指针的节点,用于解决哈希冲突。
  • 哈希冲突的解决方法是采用链表法(链表存储相同哈希值的键值对)。

获取锁的方式

  • 在Java 7中,获取锁的方式是通过synchronized关键字来实现的。
  • 每个Segment维护自己的锁,并且对于读操作采用乐观锁机制,对于写操作采用悲观锁机制。

ConcurrentHashMap机构

X3I28资讯网——每日最新资讯28at.com


X3I28资讯网——每日最新资讯28at.com

Java 8中的ConcurrentHashMap实现原理:X3I28资讯网——每日最新资讯28at.com

CAS操作和Synchronized

  • Java 8中的ConcurrentHashMap使用CAS(Compare and Swap)操作来实现并发安全性。
  • 使用CAS操作可以避免锁的竞争和阻塞。
  • Java 8中的ConcurrentHashMap还引入了一种称为"红黑树"的新数据结构,用于优化存储大量键值对的情况。

Node数组和红黑树:

  • Java 8中的ConcurrentHashMap使用了类似HashMap的Node数组来存储键值对。
  • 当某个位置的链表长度超过一定阈值时,会将链表转换为红黑树,以提高查找、插入和删除操作的效率。
  • 红黑树是一种平衡二叉树,具有较快的查找和插入性能。

分段锁的改进:

  • Java 8中的ConcurrentHashMap取消了分段锁机制,采用更细粒度的锁来实现并发控制。
  • ConcurrentHashMap的数据结构被分割成多个独立的部分,每个部分维护自己的锁。
  • 通过细粒度的锁机制,使得读操作可以并发执行,提高了并发性能。

ConcurrentHashMap机构

X3I28资讯网——每日最新资讯28at.com


X3I28资讯网——每日最新资讯28at.com

总结:X3I28资讯网——每日最新资讯28at.com

Java 7中的ConcurrentHashMap:使用了分段锁机制,存储结构为数组+链表,锁的粒度是基于段的,不支持动态扩容。X3I28资讯网——每日最新资讯28at.com

Java 8中的ConcurrentHashMap:使用CAS+Synchronized实现线程安全性,存储结构为数组+链表/红黑树+链表,锁的粒度更细,支持动态扩容,并引入了并发度的概念。X3I28资讯网——每日最新资讯28at.com

这些改进使Java 8的ConcurrentHashMap在并发性能、内存占用和可扩展性方面得到了显著的提升,适用于高并发的多线程环境下的安全哈希表操作。X3I28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-12705-0.htmlJava 7与 Java 8中ConcurrentHashMap的实现原理对比分析

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 越来越多开源项目停更,Java 生态受影响最大

下一篇: 十个优秀的编程范式,你已经用过了几个?

标签:
  • 热门焦点
  • 一加首款折叠屏!一加Open渲染图出炉:罕见单手可握小尺寸

    8月5日消息,此前就有爆料称,一加首款折叠屏手机将会在第三季度上市,如今随着时间临近,新机的各种消息也开始浮出水面。据悉,这款新机将会被命名为“On
  • K6:面向开发人员的现代负载测试工具

    K6 是一个开源负载测试工具,可以轻松编写、运行和分析性能测试。它建立在 Go 和 JavaScript 之上,它被设计为功能强大、可扩展且易于使用。k6 可用于测试各种应用程序,包括 Web
  • 破圈是B站头上的紧箍咒

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之每年的暑期档都少不了瞄准追剧女孩们的古偶剧集,2021年有优酷的《山河令》,2022年有爱奇艺的《苍兰诀》,今年却轮到小破站抓住了追
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • iQOO Neo8 Pro即将开售:到手价3099元起 安卓性能最强旗舰

    5月23日,iQOO如期举行了新品发布会,全新的iQOO Neo8系列也正式与大家见面,包含iQOO Neo8和iQOO Neo8 Pro两个版本,其中标准版搭载高通骁龙8+,而Pro版更
  • 世界人工智能大会国际日开幕式活动在世博展览馆开启

    30日上午,世界人工智能大会国际日开幕式活动在世博展览馆开启,聚集国际城市代表、重量级院士专家、国际创新企业代表,共同打造人工智能交流平台。上海市副市
  • 亲历马斯克血洗Twitter,硅谷的苦日子在后头

    文/刘哲铭  编辑/李薇  马斯克再次挥下裁员大刀。  美国时间11月14日,Twitter约4400名外包员工遭解雇,此次被解雇的员工的主要工作为内容审核等。此前,T
  • 荣耀Magic4 至臻版 首创智慧隐私通话 强劲影音系统

    2022年第一季度临近尾声,在该季度内,许多品牌陆续发布自己的最新产品,让大家从全新的角度来了解当今的手机技术。手机是电子设备中,更新迭代十分迅速的一款产品,基
Top