欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > IT业 > 【学习笔记】深入理解Java虚拟机学习笔记——第11章 后端编译与优化

【学习笔记】深入理解Java虚拟机学习笔记——第11章 后端编译与优化

2025/6/23 17:01:44 来源:https://blog.csdn.net/Lchen_kk/article/details/148830860  浏览:    关键词:【学习笔记】深入理解Java虚拟机学习笔记——第11章 后端编译与优化

第11章 后端编译与优化

11.1 概述

11.2 即时编译器

11.2.1 解释器与编译器

C1客户端编译器:优化力度小,编译快
C2服务端编译器:优化力度大,编译慢
解释器会在解释执行时收集运行数据供编译使用,以上各行为是否存在与占比情况由运行参数与版本决定

11.2.2 编译对象与触发条件

热点代码:多次调用的方法,多次执行的循环体(也会编译方法体,栈上替换)
热点代码探测方式:
1>基于采样的热点探测:周期检查各线程调用栈,经常出现在栈顶则为热点代码
优点:易于获得调用栈信息
缺点:易受阻塞扰乱热点探测
2>基于计数器的热点探测:为每个方法建立调用计数器
优点:统计调用次数准确
缺点:不能获取调用关系
Hotspot虚拟机使用第二种计数器,方法调用与循环都有各自的计数器(默认C1 1500次,C2 10000次)【可配置】
【一个方法调用时,先查看是否有编译后的版本,有则执行。无则计数器+1,达到阈值后提交一个该方法编译请求,然后继续调用解释器执行方法,编译成功后会通过编译后的代码执行。若方法一段时间内还未达热点,会减少一般调用次数统计】
回边计数:阈值计算(C1默认 13995,C2默认10700)
若存在已编译版本则执行,否则计数器+1且判断是否达到阈值,打到发送编译请求,并将回边计数减小,继续执行。
回边计数溢出时,会把方法调用计数一并溢出。

11.2.3 编译过程

客户端:三段式,重点关注局部优化而放弃全局优化
服务端:优化强度堪比c++ -02参数(无用代码消除、循环展开等…)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词