JIT(just in time)即时编译器

不想你离开。 提交于 2019-12-03 12:08:17

JIT(just in time)

前端vs后端

在编译原理中,通常将编译分为前端和后端。其中前端会对程序进行词法分析、语法分析、语义分析,然后生成一个中间表达形式(称为IR:Intermediate Representation)。后端再讲这个中间表达形式进行优化,最终生成目标机器码。

在Java中,javac之后生成的就是中间表达形式(.class)

JVM在执行时,首先会逐条读取IR的指令来执行,这个过程就是解释执行的过程。当某一方法调用次数达到即时编译定义的阈值时,就会触发即时编译,这时即时编译器会将IR进行优化,并生成这个方法的机器码,后面再调用这个方法,就会直接调用机器码执行,这个就是编译执行的过程。

字节码-->机器码:
  1. 用的时候直接翻译(解释器)
  2. 用的时候直接翻译,并把常用的方法等缓存起来,下次再用的时候直接取用(CodeCache)

可以通过java -XX:+PrintFlagsFinal打印出所有参数的默认值

参考

  1. JVM系列之走进JIT
  2. 为什么 JVM 不用 JIT 全程编译?
  3. JVM杂谈之JIT
  4. 深入理解Java即时编译器(JIT)-上篇
  5. 深入理解Java即时编译器(JIT)-下篇
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!