0

0

什么是JVM的内存逃逸分析_栈上分配与标量替换带来的极大性能提升

P粉602998670

P粉602998670

发布时间:2026-03-11 09:59:32

|

205人浏览过

|

来源于php中文网

原创

逃逸分析由jit在方法成为热点后动态触发,hotspot仅支持标量替换而非栈上分配;验证需用-xx:+printescapeanalysis看逃逸判定,标量替换生效需对象完全不逃逸、类未被增强、字段类型干净且方法被内联。

什么是jvm的内存逃逸分析_栈上分配与标量替换带来的极大性能提升

逃逸分析到底有没有在运行?别猜,看日志

逃逸分析不是开关一开就“生效”的魔法,它由 JIT 编译器在方法被多次调用(成为热点)后动态触发,且结果高度依赖上下文。你写的 new Point(1, 2) 在 A 方法里可能被标量替换,在 B 方法里调用一次 return p 就立刻全局逃逸——优化直接失效。

验证唯一可靠方式是加 JVM 参数看实际分析结论:

  • -XX:+UnlockDiagnosticVMOptions -XX:+PrintEscapeAnalysis:输出每个方法中对象的逃逸判定,如 Point not escapedPoint is global escape
  • -XX:+PrintOptoAssembly(需 hsdis 支持):进一步确认是否真的做了标量替换(汇编里看不到 new 指令,只有 mov、add 等寄存器操作)
  • 注意:JDK 8u60+ 默认开启逃逸分析,但某些场景(如启用 -XX:-TieredStopAtLevel=1 禁用 C2 编译器)会自动关闭

栈上分配为什么总没看到效果?

HotSpot JVM 目前(截至 2026 年)**并未真正实现栈上分配(Stack Allocation)**。这是最容易被资料误导的一点:大量文章把“逃逸分析通过 → 栈上分配”当成既定事实,但 HotSpot 的源码和官方文档明确说明,它只支持标量替换作为逃逸分析的落地手段,而“栈上分配”在 HotSpot 中仍为未实现特性(仅保留逻辑占位)。

所以你不会在 GC 日志或堆内存监控里看到“栈对象减少”,也不会因开启逃逸分析而显著降低 Young GC 次数——除非标量替换成功,把对象彻底拆没了。

  • 常见误判原因:把标量替换的效果(无对象创建)当成栈上分配(对象在栈帧里)
  • 真正影响 GC 的,是标量替换后连堆分配都跳过了,而不是对象从堆挪到了栈
  • 如果你在 JVM 日志里看到 stack allocation failed: too large,那基本可以确定你正在用非 HotSpot 虚拟机(如 Excelsior JET),或者日志被错误引用

标量替换生效的硬性条件有哪些?

标量替换是逃逸分析最实用、也是目前 HotSpot 唯一稳定落地的优化。但它很“挑人”,不满足任一条件就会退回到普通堆分配。

Memo AI
Memo AI

AI音视频转文字及字幕翻译工具

下载
  • 对象必须 完全不逃逸:不能赋值给任何字段(this.p = new Point())、不能放入数组/集合、不能作为参数传给其他方法(哪怕只是 log(p))、不能被反射或 toString() 访问
  • 类不能被动态增强:Spring AOP/CGLIB、Hibernate 字节码织入生成的代理类,JIT 无法做字段级推断,直接放弃替换
  • 字段类型要“干净”:若 Point 里有个 String name,而该 String 本身又逃逸了,整个 Point 就无法被完全替换;但如果 name 是常量字符串(来自字符串池),且未被外部引用,仍有可能部分替换
  • 方法必须被内联:如果 calculateDistance() 调用了 getP1(),而 getP1() 没被内联,JIT 就无法确认返回的 Point 是否逃逸

同步消除(锁消除)怎么突然变快了?

你写 new StringBuffer().append("a").append("b"),明明用了 synchronized 方法,性能却和 StringBuilder 差不多?这就是逃逸分析触发的同步消除。

JIT 发现这个 StringBuffer 实例:

  • 只在当前方法内创建
  • 所有方法调用都在单线程栈内完成
  • 没有引用被传出(没 return、没 setField、没进容器)
→ 确认它不可能被其他线程竞争 → 直接把所有 synchronized 字节码抹掉,连 MonitorEntry 都不进。

但注意:一旦你把它塞进 ThreadLocal、静态 Map,或传给一个未内联的工具方法,锁就回来了——不是 JIT 失效,而是逃逸判定变了。

这解释了为什么有些“临时拼字符串”场景下 StringBufferStringBuilder 性能几乎无差别,而另一些看似相似的代码却慢一截:差的不是类,是逃逸路径。

真正难的是让 JIT “看全”整个调用链,而不仅仅是你的那一行 new。它不像人眼能跳读逻辑,它得把每条字节码路径都静态推演清楚——这点,连很多资深开发者都会下意识忽略。

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

156

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

hibernate和mybatis有哪些区别
hibernate和mybatis有哪些区别

hibernate和mybatis的区别:1、实现方式;2、性能;3、对象管理的对比;4、缓存机制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

158

2024.02.23

Hibernate框架介绍
Hibernate框架介绍

本专题整合了hibernate框架相关内容,阅读专题下面的文章了解更多详细内容。

93

2025.08.06

Java Hibernate框架
Java Hibernate框架

本专题聚焦 Java 主流 ORM 框架 Hibernate 的学习与应用,系统讲解对象关系映射、实体类与表映射、HQL 查询、事务管理、缓存机制与性能优化。通过电商平台、企业管理系统和博客项目等实战案例,帮助学员掌握 Hibernate 在持久层开发中的核心技能。

39

2025.09.02

Hibernate框架搭建
Hibernate框架搭建

本专题整合了Hibernate框架用法,阅读专题下面的文章了解更多详细内容。

72

2025.10.14

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1010

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1565

2023.10.24

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号