zoukankan      html  css  js  c++  java
  • 133 并发容器类 map

    HashMap:

    jdk1.7

       底层存储 entry数组

        查询使用hash表算法

        h&(lenght-1) --- 取模计算数组下标

        下标相同,组成链表,顺序查找

         k,v总数超过一定比例 引发数组扩容 负载因子*length

         扩容方法 transfor 遍历全部元素 重新取模 放入数组

          扩容中无法保证数据问题 线程不安全。

    jdk 1.8:

        链表长度超过8转换红黑树----低于8 此时红黑树插入慢 查找差不多。

        

    concurrentHashMap:

       

    jdk1.7:

       segment---特定的hashtable数组

       segment数组本身不扩容,segment自身扩容。

       传入 segment数组 大小---并发度

       分段锁方式(segment)

    jdk1.8:

         抛弃了分段锁,类似hashmap的结构:

         cas操作+synchronized保证线程安全,

          null--直接cas,成功赋值,失败自旋。

         不为null--synchronized 加锁操作,锁住链表表头

          由于链表结构数据量相对少,锁粒度小,并发度高,性能好。

    concurrentSkipListMap :

    key值有排序

    headindex入口 插入时随机生成索引,查询时跳过部分元素 加速查询

    索引可以出现粒度更大的高级索引 

    删除节点时节点上的索引同步删除 同时影响headindex上的索引层级。

       

        

  • 相关阅读:
    vue数组和对象不能直接赋值
    数组内部的对象监听问题
    vue知识点(工作中遇到)
    Array数组
    js对象操作
    Vue-router
    sublime text 3 常用插件 —— SFTP
    Python中的线程和进程
    python中的sockeserver模块简单实用
    python利用socket写一个文件上传
  • 原文地址:https://www.cnblogs.com/windghost/p/12337152.html
Copyright © 2011-2022 走看看