码迷,mamicode.com
首页 > 其他好文 > 详细

ConcurrentHashMap 结构 1.7 与1.8

时间:2019-09-29 22:13:19      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:get   直接   log   blog   article   hashmap   ati   entity   结构   

1.结构

1.7 segment+HashEntity+Unsafe

1.8 移除Segment,使锁的粒度更小,Synchronized+CAS+Node+Unsafe

2. put()

1.7 先定位 Segment,再定位桶, put 全程加锁,没有获取锁的线程提前找桶的位置,并最多自旋64次获取锁,超过则挂起

18. 由于移除了Segment,类似HashMap.可以直接定位到桶,拿到 first 节点后进行判断

  1.为空则 CAS 插入

  2.为 -1 则说明再扩容,咋跟着一起扩容

  3. else 则加锁 put 

3.get()

基本类似,由于value 声明为 volatile ,保证修改可见性

4.resize()

1.7:跟HashMap步骤一样,只不过是搬到单线程中执行,避免了HashMap在1.7中扩容时死循环的问题,保证线程安全。

1.8:支持并发扩容,HashMap扩容在1.8中由头插改为尾插(为了避免死循环问题),ConcurrentHashmap也是,迁移也是从尾部开始,扩容前在桶的头部放置一个hash值为-1的节点,这样别的线程访问时就能判断是否该桶已经被其他线程处理过了。

5.size()

1.7:很经典的思路:计算两次,如果不变则返回计算结果,若不一致,则锁住所有的Segment求和。

1.8:用baseCount来存储当前的节点个数,这就设计到baseCount并发环境下修改的问题(说实话我没看懂-_-!)。

参考:https://blog.csdn.net/u013374645/article/details/88700927

 

ConcurrentHashMap 结构 1.7 与1.8

标签:get   直接   log   blog   article   hashmap   ati   entity   结构   

原文地址:https://www.cnblogs.com/baizhuang/p/11609823.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!