0

0

怎么理解Java的JIT即时编译器_热点代码(HotSpot)探测机制

P粉602998670

P粉602998670

发布时间:2026-03-11 13:46:03

|

349人浏览过

|

来源于php中文网

原创

jit只编译hotspot代码是为了权衡编译开销与性能收益,仅对调用≥10000次或循环回边≥9333次的方法编译,通过-xx:+printcompilation等参数可验证是否编译成功。

怎么理解java的jit即时编译器_热点代码(hotspot)探测机制

Java的JIT为什么只编译hotspot代码,而不是所有代码?

因为编译本身有开销:生成本地机器码要耗CPU、内存,还可能拖慢启动速度。JIT不追求“全量编译”,而是赌——把运行最频繁、对性能影响最大的那部分代码(即hotspot)编译掉,其余仍走解释执行。这是权衡后的务实选择。

实际中,一段代码要被识别为hotspot,得满足两个硬条件:

  • 方法调用次数 ≥ CompileThreshold(默认10000,Client VM是1500)
  • 循环回边(back-edge)执行次数 ≥ OnStackReplacePercentage(默认9333,基于CompileThreshold动态算)

注意:hotspot不是按“代码行”或“方法名”静态标记的,而是在运行时由HotSpot VMmethodData结构实时统计+触发的。你改了代码逻辑但没触发阈值,它就永远不编译。

怎么确认某段代码真被JIT编译了?

靠日志,不是靠猜。加JVM参数打开编译日志是最直接的方式:

立即学习Java免费学习笔记(深入)”;

-XX:+PrintCompilation -XX:+UnlockDiagnosticVMOptions -XX:+PrintInlining

输出里看到类似这样的行,就说明成功了:

123   45       3       java.lang.String::hashCode (67 bytes)

其中45是编译ID,3表示编译级别(3=C14=C2),(67 bytes)是生成的本地码大小。如果只看到made not entrantmade zombie,说明这段代码被优化后又废弃了——这很常见,尤其在开启-XX:+TieredStopAtLevel=1时。

皮卡智能
皮卡智能

AI驱动高效视觉设计平台

下载

容易踩的坑:

  • 没加-XX:+UnlockDiagnosticVMOptions-XX:+PrintInlining会静默失效
  • 在IDE里跑main方法,往往达不到默认10000次调用,建议用循环压测+-XX:CompileThreshold=100临时调低
  • PrintCompilation不显示失败原因,想查具体为何没编译,得配合-XX:+TraceClassLoading-XX:+LogCompilation(生成hotspot_pid*.log

invokedynamic和Lambda表达式怎么影响hotspot判定?

它们让热点探测变复杂了。Lambda本质是通过invokedynamic指令绑定到CallSite,而CallSite可能被多次重写(如第一次指向解释版,后续指向编译版)。JIT不会直接编译Lambda体,而是编译它最终绑定的那个目标方法(比如lambda$foo$0这种合成方法)。

这意味着:

  • 如果你反复创建新Lambda(如在循环里写list.forEach(x -> {...})),每次都是新CallSite,统计归零,大概率编译不了
  • invokedynamic本身的解析开销会被计入方法调用计数,但它自己不会被编译——真正被编译的是它最终跳转到的那个方法
  • -XX:+PrintAssembly(需hsdis)看汇编时,搜不到lambda$名,得找它实际委托的方法名

为什么有些代码明明很热,却始终没被JIT?

最常见的三个硬性拦截点:

  • 方法太大:默认超过8000字节字节码(由-XX:MaxTrivialSize-XX:MaxInlineSize等控制)直接不进C1/C2编译队列
  • 栈上替换(OSR)失败:长循环里刚达到回边阈值,但此时栈帧太深或有未处理异常,JIT放弃OSR,继续解释执行
  • 去优化(deoptimization)太频繁:比如类型推测失败(java.lang.ClassCastException在编译后抛出),VM会把已编译方法标为not entrant,并降级回解释——这时你再看PrintCompilation,会发现同一方法ID反复出现又消失

这些机制不是bug,是JIT在“激进优化”和“语义正确”之间拉锯的结果。越想压榨性能,越得接受这种动态性——它不像AOT那样一锤定音,也不像纯解释器那样稳定可预测。

真正难的不是理解探测逻辑,而是当性能卡点出现在“本该编译却没编译”的时候,得一层层剥开CompileCommandPrintInliningLogCompilation输出,看清到底是阈值没到、被拒之门外,还是刚编完就被踢出去了。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1724

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

397

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

1037

2025.04.24

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

266

2025.12.04

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

215

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

192

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

61

2026.01.05

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11.1万人学习

Java 教程
Java 教程

共578课时 | 80.5万人学习

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

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