【学习笔记】深入理解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参数(无用代码消除、循环展开等...)