java 并发编程之concurrentHashMap

之所以会出现concurrentHashMap,是因为hashmap在实现上为了效率高,舍弃了线程安全的考虑。不像hashtable加入了synchronized的关键字来保证线程安全。但是如果在多线程环境下使用hashtable 就会导致锁竞争严重,系统的整体性能会大大降低。而concurrenthashmap采用的是锁分段技术,既保证了系统性能的高效,同时也实现了线程安全。下面我们来看下concurrenthashmap类的继承关系。
这里写图片描述

从这里看出concurrentHashMap是有segment数组结构和hashEntry数组结构构成。segment 是可重入锁ReentrantLock,在concurrentHashMap中扮演锁的角色。而HashEntry扮演存储键值的角色.

concurrentHashMap的初始化:
concurrentHashMap初始化方法是通过initialCapacity,loadFactory,concurrentlevel几个参数来初始化segments数组,段偏移量segmentShift,段掩码segmentMask和每个segment 里的HashEntry数组。
初始化segments数组。以下是源代码:
这里写图片描述
可以看到,为了能通过按位与的哈希算法来定位segment的数组大小,必须使用大于或等于concurrentlevel的2的N次方的最小数来作为数组的长度。

定位segment
concurrenthashmap采用锁分段技术来保护不同段的数据,在访问的时候需要通过哈希定位计算来获取segment的位置。通过对hashcode再hash,减少了哈希冲突的可能性。

哈希扩容
hashmap在扩容方案上采用的是先将元素插入到map中,然后判断当前

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值