ConcurrentHashMap

本文详细探讨了ConcurrentHashMap的实现原理,包括其与HashMap的异同、存储结构、关键字段、构造器、put操作的树化过程、初始化、大小计算、扩容策略以及在并发环境下的线程安全特性。特别强调了ConcurrentHashMap如何通过分段锁实现高效并发,并解释了在不同操作中如何避免锁竞争和协助扩容。
摘要由CSDN通过智能技术生成

ConcurrentHashMap

看ConcurrentHashMap,需要先了解HashMap

ConcurrentHashMap和HashMap相同的地方:

  • 数组长度都是2的n次幂
  • Node结构都相同
  • hash值都是原hash值高低位异或的结果

ConcurrentHashMap和HashMap不同的地方:

  • 数组初始长度:带容量c造器下,Concurrent要运算 c*1.5+1,可避免扩容
  • key不能为空
  • ConcurrentHashMap的hash值的符号位一定是0,拒绝负数
  • 负载因子只有在构造器中有用,实际扩容时,会用0.75(n-n>>2)

ConcurrentHashMap和HashTable的区别:

  • HashTable只有一把锁,所有线程都需要竞争这一把锁

  • ConcurrentHashMap是按桶位来锁,有效避免了多个线程竞争锁的问题

存储结构:

同HashMap

关键字段:

  • sizeCtl

    • sizeCtl<-1时, 高16位是扩容标识戳,低16位= n + 1,n是正在进行扩容的线程数
    • sizeCtl== -1, 正在进行初始化
    • sizeCtl==0,数组尚未初始化,下一个数组长度是16
    • sizeCtl>0
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

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

    抵扣说明:

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

    余额充值