当前位置: 首页 > news >正文

Java常见技术分享-18-多线程安全-进阶模块-并发集合与线程池

基本上 Java中重要的多线程编程重要的类都在java.util.concurrent包里边

并发集合 - ConcurrentHashMap

具体实现
Java7

核心实现: 分段锁(原本是 给整个哈希表加全局锁, 变成了对数组的某一范围进行加锁, 通过缩小锁的范围,让更多的操作可以并行执行,保证线程安全)

Java8

核心实现: CAS加上synchronized

核心流程:

volatile 针对哈希表数组的 每一个元素 对应的 链表头 或者 红黑树 根节点 进行修饰 保证了 可见性。

当线程尝试 去 设置 值的时候,比如put(key , value ) ,根据 key找到对应的下标, 然后在插入的操作前 去内存读取 数组中这个下标 对应的 链表头节点(【该数组索引位的旧头节点的引用】), 接着就会执行CAS操作 , compare比较的是 自己当前感知到的 【该数组索引位的旧头节点的引用】, 把这个当作预期值, 如果预期值一致, 那么把 这个索引位 的值更新成 新节点的引用, 这个新节点 后面理论上就是旧的节点。

如果CAS 操作失败, 说明已经有别的线程已经操作了, 失败就会自旋重试 , 典型乐观锁, 当线程竞争激烈的时候, 就会对 链表头节点对象 加synchronized关键字 ,进行加锁
比如synchronized(node) { 插入删除操作}

http://www.jsqmd.com/news/155429/

相关文章:

  • 以太网二层协议有哪些?
  • 【python大数据毕设实战】音乐内容智能推荐与市场趋势分析系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习、实战教学
  • Linux 入门必掌握的十大命令
  • 算法-回溯-14
  • 《创业之路》-761-《架构思维:从程序员到CTO》第四部 - 架构师的职业规划与能力成长:从执行者到战略引领者的跃迁,技术、业务与软技能的三角支撑。
  • YOLO与Prometheus Thanos Ruler集成:跨集群告警规则
  • YOLO与Kubeflow MLOps集成:端到端机器学习 pipeline
  • YOLO在噪音污染监测的应用:施工机械视觉识别
  • TCN-BiGRU回归+特征贡献SHAP分析+新数据预测+多输出,MATLAB代码
  • YOLO目标检测中的知识蒸馏实践:Teacher-Student架构
  • 《创业之路》-763-公司的组织架构服务于产品技术架构,技术架构服务于组织的业务服务,组织的业务服务于组织的战略,组织的战略服务于政府的规划、政府的规划服务于国家的战略。上下贯通,一脉相承,方为顺势。
  • 提示工程实战:如何用Prompt让游戏AI理解玩家的“隐藏需求”
  • 【毕业设计】基于SpringBoot的儿童医院挂号管理系统的设计与实现(源码+文档+远程调试,全bao定制等)
  • 推荐阅读:深入解析C语言编程中的指针与内存管理
  • YOLO模型训练资源使用趋势预测:基于历史数据分析
  • 事件委托(Event Delegation)
  • 【教程4>第10章>第11节】基于FPGA的图像双边滤波开发——3*3窗口像素提取/高斯权值/exp指数运算
  • YOLO模型缓存一致性维护:主从同步与失效传播
  • 推荐阅读:如何在C语言中通过函数返回结构体
  • 构建LLM支持的AI Agent创新思维系统
  • 采样率、信号频谱/频谱混叠原理与matlab仿真分析
  • YOLO模型灰度发布期间的竞品对比分析
  • YOLO在空气质量监测的应用:扬尘颗粒物视觉识别
  • ArchLinux 安装 VMware Workstation
  • YOLO在电磁辐射监测的应用:基站设备视觉识别
  • 高中语法练习解析100篇-007-Esther’s Gift of Books 埃丝特的赠书之情 - new
  • 年终复盘2.0:NLP自动萃取经验教训,构建可执行策略库
  • PHP反序列化
  • 新建项目记录
  • YOLO与Tekton流水线集成:企业级CI/CD实践