Java DeepJava学习笔记

Java JIT Just In Time 即时编译

2016-12-28  本文已影响775人  专职跑龙套

更多 Java 虚拟机方面的文章,请参见文集《Java 虚拟机》


前端编译器 VS 后端编译器

JIT 即时编译

当 JVM 发现某个方法或代码块执行特别频繁时,就将其认定为 热点代码(Hot Spot Code)。在程序运行期间,JVM 将这些热点代码编译为与本地平台相关的机器码,并进行各层次的优化,从而提升热点代码的执行效率。

基本流程如下:


JIT 即时编译

如何检测热点代码(Hot Spot Code):

即时编译的设置及优化

初级调优

HotSpot 虚拟机内置两个 JIT 编译器:

Java 8 支持多层编译,即程序启动时使用 C1 编译,样本足够后使用 C2 编译:

优化代码缓存

如果缓存过小,有些热点代码可能不会被 JIT 编译。
C1 编译的类较多,可能导致代码缓存不够用。
设置代码缓存大小:-XX:ReservedCodeCacheSize = 32m

编译阈值

即计数器的阈值,默认为10000,即方法计数器和回边计数器的总和达到了10000就触发 JIT 编译。
设置编译阈值:-XX:CompileThreshold = 10000

内联 Inline

将方法的代码复制到发起调用的方法里,以消除方法调用
因为调用一个小方法可能比直接执行该小方法对应的代码更耗时。

如何让方法更容易被内联:拆分不常访问的路径。例如:

public void f() {
  if(most case) {
    ...
  }
  else {
    ... // 将不常访问的路径的代码拆分到函数 g() 中
    ... // 以降低整体代码的大小,使得 most case 中的代码可以被内联
  }
}

打印 JIT 编译信息

java -XX:PrintCompilation -XX:+UnlockDiagnosticVMOptions -XX:PrintInline > a.out

上一篇 下一篇

猜你喜欢

热点阅读