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

  • 相关阅读:
    IBatis简介
    cntlm代理使用
    bash快捷键你知道几个?
    django的Form中添加属性
    EMACS 中文显示为方框
    git合并子树
    算法 排序 python 实现堆排序
    android org.eclipse.wst.sse.core 0.0.0' but it could not be found
    我的EMACS配置
    python 输入# 自动跳到行首
  • 原文地址:https://www.cnblogs.com/baizhuang/p/11609823.html
Copyright © 2011-2022 走看看