大多数开发人员都知道,Java源文件需要编译成.class文件才能在JVM中运行。如果继续追问,许多开发人员还会告诉你说.class中的字节码首先会被JVM解释,但在稍后即时(JIT)编译。然而很多人将字节码含糊地理解为“在某种虚构的或简化的CPU上运行的机器码”。
实际上,JVM字节码更像是中途的驿站,是一种从人类可读的源码向机器码过度的中间状态。用编译原理术语讲,字节码实际上是一种中间语言(IL)形态,不是真正的机器码。也就是说,将Java源码变成字节码的过程不是C或C++程序员所理解的那种编译。Java所谓的编译器javac也不同于gcc,实际上它只是一个针对Java源码生成类文件的工具。Java体系中真正的编译器是JIT,如下图所示:
有人说Java是“动态编译”的,他们所说的编译是指JIT的运行时编译,不是指构建时创建类文件的过程。
所以如果被问及“Java是编译型语言还是解释型语言”,你可以回答“都是”。