ConcurrentHashMap底层原理

news/2024/10/5 20:20:40/文章来源:https://www.cnblogs.com/jock766/p/18274226

一、ConcurrentHashMap底层结构

二、ConcurrentHashMap类的成员变量

  public class ConcurrentHashMap<K, V>extends AbstractMap<K, V>implements ConcurrentMap<K, V>, Serializable {// 数组最大容量private static final int MAXIMUM_CAPACITY = 1 << 30;// 数组初始容量private static final int DEFAULT_CAPACITY = 16;// 负载因子(超过就要扩容)private static final float LOAD_FACTOR = 0.75f;// 树化阈值(节点数超过阈值,需要把链表转换成红黑树)static final int TREEIFY_THRESHOLD = 8;// 反树化阈值(当红黑树节点数量小于此阈值,重新转换成链表)static final int UNTREEIFY_THRESHOLD = 6;// 转换成红黑树的最少元素数量static final int MIN_TREEIFY_CAPACITY = 64;// 特殊节点的哈希值static final int MOVED = -1; // 转移节点的哈希值static final int TREEBIN = -2; // 红黑树根节点的哈希值static final int RESERVED = -3; // 临时节点的哈希值// 节点类型数组transient volatile Node<K, V>[] table;// 备用数组,用于扩容private transient volatile Node<K, V>[] nextTable;// 元素个数(没有统计并发的操作)private transient volatile long baseCount;// 并发的元素个数(想要统计总数量,需要加上baseCount)private transient volatile CounterCell[] counterCells;/*** sizeCtl用来控制table的初始化和扩容操作的过程,其值大致如下:*     -1 代表table正在初始化,其他线程应该交出CPU时间片*     -N 表示有N-1个线程正在进行扩容操作,严格来说,当其为负数时,只用到其低16位,如果其低16位数值为M,此时有M-1个线程进行扩容*     大于0分两种情况:如果table未初始化,sizeCtl表示table需要初始化的大小;如果table初始化完成,sizeCtl表示table的容量,默认是table大小的0.75倍*/private transient volatile int sizeCtl;}

ConcurrentHashMap还定义了4个节点内部类,分别是链表节点Node、红黑树节点TreeNode、管理红黑树的容器TreeBin、扩容时的临时转移节点ForwardingNode

    public class ConcurrentHashMap<K, V>extends AbstractMap<K, V>implements ConcurrentMap<K, V>, Serializable {/*** 链表节点类*/static class Node<K, V> implements Map.Entry<K, V> {final int hash;final K key;volatile V val;volatile Node<K, V> next;Node(int hash, K key, V val, Node<K, V> next) {this.hash = hash;this.key = key;this.val = val;this.next = next;}}/*** 红黑树节点类*/static final class TreeNode<K, V> extends Node<K, V> {TreeNode<K, V> parent;TreeNode<K, V> left;TreeNode<K, V> right;TreeNode<K, V> prev;boolean red;TreeNode(int hash, K key, V val, Node<K, V> next,TreeNode<K, V> parent) {super(hash, key, val, next);this.parent = parent;}}/*** 管理红黑树的容器*/static final class TreeBin<K, V> extends Node<K, V> {TreeNode<K, V> root;volatile TreeNode<K, V> first;volatile Thread waiter;volatile int lockState;}/*** 转移节点(扩容时使用)*/static final class ForwardingNode<K, V> extends Node<K, V> {final Node<K, V>[] nextTable;ForwardingNode(Node<K, V>[] tab) {super(MOVED, null, null, null);this.nextTable = tab;}}}

三、构造方法

ConcurrentHashMap常见的构造方法有四个:

  • 无参构造方法

  • 指定容量大小的构造方法

  • 指定容量大小、负载系数的构造方法

  • 指定容量大小、负载系数、并发度的构造方法

      // 无参初始化Map<Integer, Integer> map1 = new ConcurrentHashMap<>();// 指定容量大小的初始化Map<Integer, Integer> map2 = new ConcurrentHashMap<>(16);// 指定容量大小、负载系数的初始化Map<Integer, Integer> map3 = new ConcurrentHashMap<>(16, 0.75f);// 指定容量大小、负载系数、并发度的初始化Map<Integer, Integer> map4 = new ConcurrentHashMap<>(16, 0.75f, 1);
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/733010.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Compute Shader

Compute Shader 是一种高级功能,用于在 GPU 上执行并行计算任务。它非常适合处理大量数据,执行复杂的数学计算,或在高性能图形处理中使用。 常用于,需要密集的并行多线程计算,CPU不擅长并行计算,丢给GPU去算,然后把结果返回给CPU,或者直接渲染到屏幕上。 需要图形API,…

指数增强策略:如何通过动态调整权重击败沪深300?

哈喽,大家好,我是木头左!今天,将深入探讨一种特定的指数增强策略,这种策略以0.8为初始权重跟踪沪深300中权重大于0.35%的成份股,并根据个股的表现动态调整权重。让一起启航,探索这一策略如何帮助在波动的市场中稳健前行。 策略概述:权重与表现的舞蹈 在传统的指数跟踪策…

IP地址的概念及IP子网划分

十进制与二进制的转换192. 168. 10. 111000000 10101000 00001010 00000001幂27 26 25 24 23 22 21 20128 64 32 16 8 4 2 1位1 1 0 0 0 0 0 0=128+64=192 IP地址的划分网络掩码(Network Mask)IP地址类型 1)网络地址:用于标识一个网络,主机位全0的地址。 2)广播地址:用于…

远程控制软件哪个好用?精选安全远控软件ToDesk

远程控制软件的妙用,对于打工人来说莫过于能快速处理下班后的紧急工作。即使远在千里,也能毫无障碍远控办公电脑,不需要随身携带笔记本,也不用受限于地点。 但市面上远程控制软件良莠不齐,而且有些软件还时不时掉链子,在远控安全方面也有所顾虑,怎样才能火眼金睛找到最适…

旧手机、平板不再吃灰,装上ToDesk秒变办公利器

家里有好久用不到却又不舍得处理的手机、平板怎么办?教你一招,包你高效利用旧设备,轻轻松松为工作、学习、娱乐等方面都赋能! 操作方法很简单,仅需要在以往不用以及当前常用的各个设备中都装上ToDesk远程控制软件便能更实用。通过巧妙利用,它不仅能够帮助用户将旧手机或平…

ToDesk云电脑游戏数量?高性能显卡云桌面

玩游戏最怕遇到电脑配置跟不上,操作卡成狗不说,画面还一卡卡的,游戏体验极差。 最近被人安利了ToDesk的云电脑,可能是刚推出的,配置价格都很能打,浅用了一波拿来打APEX和荒野大镖客,体验有点惊喜到我!用ToDesk云电脑来打游戏,还不需要浪费时间在安装游戏上,多达数百种…

电脑被远程控制了怎么办,用ToDesk远控安全无忧

随着居家办公和数字游民的兴起,远程控制软件成为许多人的首选办公软件。 但近期多起诈骗案中利用远程软件的共享屏幕进行作案,让人不禁开始担心使用远程软件是否安全?如果遇到陌生人对你进行手机远程控制又该如何应对? 今天小圈以远程控制软件ToDesk为教材,给你们整理了四…

6.24.2 数据库漏洞口令应急取证

windows日志分析神器 logonTracer-外内网日志 github下载:#JPCERTCC/LogonTracer:通过可视化和分析 Windows 事件日志来调查恶意 Windows 登录 (github.com) 数据库日志分析-爆破注入等 常见数据库攻击包括弱口令、SQL注入、提升权限、窃取备份等;对数据库日志进行分析,发现…

基于LangChain手工测试用例生成工具

在编写测试用例的过程中,测试工程师会通过需求文档,研发的概要设计等信息编写测试用例,测试用例的输出格式常常为思维导图或者excel等数据信息。在以上的流程中,一个测试工程师可以根据比较详细的需求文档以及研发的概要设计输出对应的测试点,以及测试用例。而如果和人工智…

Ros Slam 之Nav2导航框架介绍与安装

1.Nav2是什么Nav2项目继承并发扬ROS导航栈的精神。该项目力求以安全的方式让移动机器人从A点移动到B点。Nav2也可以应用于其他应用,包括机器人导航,如下动态点跟踪,在这个过程中需要完成动态路径规划、计算电机的速度、避免障碍、恢复行为。2.Nav2如何做到的Nav2使用行为树调…

Cilium VxLAN with eBPF 模式

Cilium VxLAN with eBPF 模式Cilium VxLAN with eBPF 模式 查看此文档前需要熟悉 VxLAN 相关信息,可以查看此文档 Linux 虚拟网络 VXLAN 一、环境信息主机 IPubuntu 172.16.94.141软件 版本docker 26.1.4helm v3.15.0-rc.2kind 0.18.0kubernetes 1.23.4ubuntu os Ubuntu 20.04…

Profibus协议转profinet协议网关模块连接电机保护器与PLC通讯

本文介绍了Profibus协议转Profinet协议网关模块(XD-PNPBM20)在工业自动化系统中的作用。通过使用Profibus协议转Profinet协议网关模块(XD-PNPBM20),用户可以实现实现Profibus DP从站设备与Profinet主站设备之间通信的关键设备。一、背景 工业通讯中常见的协议有:Modbus协…