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