偏向锁撤销触发STW(Stop-The-World)的根本原因在于其撤销操作需要​​全局内存一致性​​和​​线程状态确定性​​,具体机制如下:


⚙️ ​​一、偏向锁撤销的核心流程​

  1. ​竞争触发撤销​
    当线程B尝试获取已被线程A偏向的锁时,JVM检测到竞争,触发撤销操作。
  2. ​挂起持有线程​
    需暂停持有偏向锁的线程A,检查其是否仍在同步块中:
    • 若线程A已退出同步块:直接撤销偏向锁,恢复为无锁状态(标志位01)。
    • 若线程A仍在同步块中:升级为轻量级锁(标志位00),线程B继续竞争。
  3. ​对象头修改​
    将对象头(Mark Word)中的线程ID移除,替换为轻量级锁指针或无锁状态。

🛑 ​​二、STW的必要性​

撤销操作必须在​​全局安全点(Safepoint)​​ 进行,原因如下:

  1. ​线程状态一致性​
    需确保所有线程(尤其是持有偏向锁的线程)处于可安全挂起的状态(如未执行字节码),防止撤销过程中线程修改对象头或栈帧。
  2. ​线程栈遍历需求​
    判断线程A是否在同步块中,需遍历其栈帧中的Lock Record(锁记录)。若线程未暂停,栈帧可能动态变化,导致数据不一致。
  3. ​内存屏障要求​
    对象头修改需原子性,且其他线程必须立即可见。STW期间可避免CPU缓存与主存不一致问题。

⏱️ ​​三、STW的性能影响​

  • ​短暂停顿​​:单次撤销通常耗时​​微秒级​​(如0.1-1ms),对低竞争场景影响小。
  • ​高并发瓶颈​​:频繁竞争会导致多次撤销,累积STW时间显著增加(如百线程竞争时可达毫秒级)。
  • ​日志示例​​:
    启用安全点日志(-XX:+PrintSafepointStatistics)可见:
    RevokeBias [threads: 200 initially_running: 5] 
    [time: spin=0.1ms block=2ms cleanup=0.5ms vmop=15ms]
    其中vmop=15ms为实际STW时间。

⚖️ ​​四、不同场景下的撤销处理​

​场景​处理方式是否需STW
持有线程已退出同步块直接恢复为无锁状态是(但操作更快)
持有线程仍在同步块中升级为轻量级锁
调用hashCode()/wait()强制撤销并升级重量级锁

调用hashCode()会覆盖Mark Word中的线程ID,强制撤销偏向锁。


🚀 ​​五、优化建议​

  1. ​禁用偏向锁​
    高并发场景(如秒杀系统)通过 -XX:-UseBiasedLocking 禁用,避免频繁撤销导致的STW。
  2. ​监控安全点​
    临时开启日志定位非GC导致的STW:
    -XX:+PrintSafepointStatistics -XX:PrintSafepointStatisticsCount=1
  3. ​升级JDK版本​
    JDK 15+ 默认关闭偏向锁,JDK 18+ 已移除该机制,彻底规避此问题。

💎 ​​总结​

偏向锁撤销触发STW的本质是​​保证内存与线程状态一致性​​的代价。在单线程场景中,偏向锁通过避免CAS操作提升性能;但在多线程竞争下,其撤销机制反而成为瓶颈。​​高并发系统应禁用偏向锁​​,选择轻量级锁(CAS)或直接使用java.util.concurrent中的并发工具(如ReentrantLock),以消除STW对延迟的影响。

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

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

相关文章

Java观察者模式详解

观察者模式(Observer Pattern)是一种行为型设计模式,它定义了对象之间的一对多依赖关系,当一个对象(主题)的状态发生改变时,所有依赖于它的对象(观察者)都会自动收到通知并更新。 核心概念 观察者模式包含以下核心角色: ‌Subje…

创世新布控球 国标

目录 结论: UDP模式 对讲 平台页面设置 设备tcp被动 旧的创世版本(平台选的设备tcp被动;设备侧无法设置) 新创世从2.8改到180上,先UDP,全报文 参考文档 结论: 对讲的tcp主被动&#xff0…

【Dify精讲】第18章:企业级功能定制

在企业级AI应用的实际部署中,你很快就会发现开源版本的标准功能往往无法满足复杂的业务需求。作为一个在多家企业实施AI系统的老兵,我深知企业级定制的痛点和需求。今天,让我们一起深入Dify的企业级功能定制,看看如何在现有架构基…

PHP $_GET 变量详解

PHP $_GET 变量详解 引言 在PHP编程中,$_GET变量是处理HTTP GET请求参数的一种非常便捷的方式。本文将详细介绍PHP $_GET变量的使用方法、特点以及在实际开发中的应用。 一、什么是$_GET变量? $_GET是一个预定义的PHP超级全局变量,用于存储HTTP GET请求中的数据。当用户…

Kafka动态配置深度解析

在分布式消息队列领域,Kafka凭借其高吞吐量、低延迟和可扩展性成为众多企业的首选。随着业务场景的日益复杂和数据流量的动态变化,静态配置已难以满足需求,Kafka的动态配置功能应运而生。通过动态配置,用户无需重启集群或中断服务…

为WIN10微软输入法的全角切换Bug禁用Shift+Space组合键

20250621 By wdhuag 目录 前言: 参考: 使用AutoHotkey屏蔽快捷键(推荐): 使用PowerToys的键盘管理器屏蔽快捷键(不推荐): 网上其它的方法: 前言: 是的…

Shell脚本调试与错误处理详解

在 Shell 脚本中,set 命令用于控制脚本的执行行为和调试选项。以下是详细解释: 1. set -e 和 set e set -e(严格错误检查): 当命令返回非零退出状态(失败)时,立即退出脚本。 示例&a…

鲲鹏服务器创建Zookeeper镜像实例

配置Kafka过程中,少不了要使用Zookeeer,这里记录一下配置Zookeeper镜像实例的过程。 创建目录 mkdir -p /data/docker/zookeeper/data mkdir -p /data/docker/zookeeper/conf mkdir -p /data/docker/zookeeper/logs说明:data目录为数据挂载…

GitHub Actions 自动 CI 测试 WorkFlow工作流搭建

大家好,我是此林。 代码托管平台 Github 我们应该比较熟悉。每次我们提交代码到 GitHub 仓库时,特别是开源项目,一般都会自动触发测试脚本运行,帮你验证代码没有引入新的错误。 这个其实就是 GitHub Actions,一般我们…

0-机器学习简介

有监督学习 目标:建立一个模型(函数),来描述输入(x)和输出(y)之间的映射关系。 价值:模型训练完成后,新的输入,模型会给出预测值输出。 注意点: 1.要有足够的训练样本 2.输入和输出之间有关联关系 3.输入…

前端跨域解决方案(6):Nginx

1 Nginx 核心 Nginx 是一个开源的高性能 HTTP 和反向代理服务器,以轻量级、高并发处理能力和低资源消耗著称。除作为 Web 服务器外,还可充当邮件代理服务器和通用的 TCP/UDP 代理服务器,广泛应用于现代 Web 架构中。 在 Windows 系统中使用…

C++智能指针编程实例

智能指针是C11引入的重要特性&#xff0c;用于自动管理动态分配的内存&#xff0c;防止内存泄漏。下面介绍几种高级智能指针编程实例。 1. 共享所有权模式 (shared_ptr) 循环引用问题及解决方案 #include <memory> #include <iostream>class B; // 前向声明clas…

单元测试总结

一、测试方案: 单元测试方案应包括以下步骤: 1.理解代码结构:仔细阅读代码,理解程序的结构、逻辑和算法。 2.制定测试目标:明确你想要测试的功能和输出结果; 3.撰写测试用例:编写涵盖所有测试目标的测试用例; 4.执行测试:运行测试用例以验证功能的正确性; 5.编写报告:根据测试…

Spring面向切面编程AOP(2)

前置通知&#xff08;Before Advice&#xff09; 前置通知在目标方法执行之前被调用&#xff0c;常用于执行一些预处理逻辑&#xff0c;例如权限验证、参数校验等。在 Spring 配置文件中&#xff0c;前置通知通过<aop:before>标签进行配置&#xff0c;以下是一个典型的示…

设备故障预测与健康管理技术:从数据到决策的工业智能进化之路​

在工业 4.0 与智能制造浪潮的推动下&#xff0c;设备故障预测与健康管理&#xff08;Prognostics and Health Management, PHM&#xff09;技术已成为企业实现数字化转型的核心驱动力。据统计&#xff0c;制造业中设备非计划停机 1 小时的平均损失高达 25 万美元&#xff0c;而…

RabbitMQ从入门到实践:消息队列核心原理与典型应用场景

在现代应用开发中&#xff0c;系统各部分之间的通信至关重要。这就是像RabbitMQ这样的消息代理发挥作用的地方。无论您是在构建微服务架构、实现任务队列&#xff0c;还是开发实时聊天应用程序&#xff0c;RabbitMQ都可能成为改变游戏规则的工具。本文将深入探讨RabbitMQ是什么…

基于Spring Boot和Vue的网上军事论坛设计与实现

目录 一.&#x1f981;前言二.&#x1f981;开源代码与组件使用情况说明三.&#x1f981;核心功能1. ✅算法设计2. ✅Java开发语言3. ✅Redis数据库4. ✅部署项目 四.&#x1f981;演示效果1. 管理员模块1.1 用户管理1.2 内容审核1.3 权限分配1.4 菜单管理1.5 字典管理 2. 用户…

LLMs基础学习(八)强化学习专题(6)

LLMs基础学习&#xff08;八&#xff09;强化学习专题&#xff08;6&#xff09; 文章目录 LLMs基础学习&#xff08;八&#xff09;强化学习专题&#xff08;6&#xff09;深度强化学习&#xff08;DQN&#xff09;DQN 起源&#xff1a;《Playing Atari with Deep Reinforceme…

JVM(10)——详解Parallel垃圾回收器

Parallel 垃圾回收器&#xff08;也称为 吞吐量优先收集器&#xff09;。它是 Java 早期&#xff08;特别是 JDK 8 及之前&#xff09;在多核处理器上的默认垃圾回收器&#xff0c;其核心设计目标是最大化应用程序的吞吐量。 一、Parallel 回收器的定位与设计目标 核心目标&am…

MySQL(91)什么是分布式数据库?

分布式数据库是一种将数据存储在多个物理位置的数据库系统。这些位置可能分布在不同的服务器、数据中心甚至地理位置。分布式数据库系统允许数据的存储、处理和访问分布在多个节点上&#xff0c;以提高数据的可用性、可靠性、可扩展性和性能。 1. 分布式数据库的特点 1.1 数据…