zoukankan      html  css  js  c++  java
  • ConcurrentHashMap 结构 1.7 与1.8

    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

  • 相关阅读:
    我和计算机
    十四周学习记录
    十五周个人作业
    怎样成为一个高手
    C语言第0次作业
    C语言博客作业03函数
    C博客作业01分支、顺序结构
    C语言博客作业02循环结构
    Rails后台,Firefox Addons前端,JS的AJAX调用
    Ruby 三元一次线性方程组
  • 原文地址:https://www.cnblogs.com/baizhuang/p/11609823.html
Copyright © 2011-2022 走看看