每日一面系列之心心念念的ConcurrentHashMap

本文深入探讨了ConcurrentHashMap与HashMap的区别,包括它们的数据结构和线程安全性。详细阐述了ConcurrentHashMap的工作原理,如put()和get()的操作流程,并对比了其与HashTable的效率和锁机制。在JDK1.8中,ConcurrentHashMap使用Synchronized代替ReentrantLock以降低锁粒度,提高性能。此外,文章还讨论了为何ConcurrentHashMap不允许key或value为null的原因。
摘要由CSDN通过智能技术生成

1.ConcurrentHashMap与HashMap有什么区别?

  1. 数据结构:HashMap的数据结构在HashMap那一篇已经有了很详细的说明,这里就不赘述了,没有看过的小伙伴可以点击这里每日一面系列之HashMap夺命连环问。在JDK1.7中ConcurrentHashMap底层采用分段数组+链表的方式实现。在JDK1.8中ConcurrentHashMap与JDK1.8中的HashMap底层数据结构一样,都是采用数组+链表或者数组+红黑树的方式实现。这二者底层数据结构都是以数组为主体的。
  2. 线程安全:HashMap是线程不安全的,ConcurrentHashMap是线程安全的。

2.说一下ConcurrentHashMap的工作原理,put()和get()的工作流程是怎样的?

存储对象时,将key和vaule传给put()方法

  1. 如果没有初始化,就调用initTable()方法对数组进行初始化;
  2. 如果没有hash冲突则直接通过CAS进行无锁插入;
  3. 如果需要扩容,就先进行扩容,扩容为原来的两倍;
  4. 如果存在hash冲突,就通过加锁的方式进行插入,从而保证线程安全。(如果是链表就按照尾插法插入,如果是红黑树就按照红黑树的数据结构进行插入);
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值