java代码是如何被机器识别的?
首先,Java作为一门高级程序语言,其语法非常复杂,直接将 Java 代码丢给机器,机器是无法识别 Java 代码的。所以,对于Java语言来说,首先是使用编译器将我们的 Java 源码(.java文件)编译成字节码文件(.class文件),之后再使用虚拟机(JVM)将字节码翻译成机器码,最后机器码才能被机器识别并执行。
请看下图:
(免费学习视频教程推荐:java视频教程)
解释如下:
其实 JVM 是无法直接运行字节码文件的,JVM 需要将字节码翻译成机器码才可以运行对应的代码逻辑。在 HotSpot 虚拟机中,有两种翻译形式:第一种是解释执行,即逐条将字节码翻译成机器码并执行;第二种是即时编译(Just-In-Time compilation,JIT),即将一个方法中包含的所有字节码编译成机器码后再执行。这两种方式各有优劣。
解释执行的优势是无须等待编译,立刻可以运行。而即时编译的优势在于实际运行速度更快。在 HotSpot 虚拟机中默认采用混合模式,综合了解释执行和即时编译两者的优点。它会先解释执行字节码,而后将其中反复执行的热点代码,以方法为单位进行即时编译。
Java 虚拟机执行 Java 字节码的时候,首先会将字节码文件加载到内存中,之后将加载后的 Java 类存放到方法区(Method Area)中。实际运行时,虚拟机会执行方法区中的代码。
在运行过程中,每次进入一个 Java 方法,Java 虚拟机会在当前线程的 Java 方法栈中生成一个栈帧,用以存放局部变量以及字节码 *** 作数。当退出当前执行方法时,无论正常返回还是异常返回,Java 虚拟机都会d出当前线程的当前栈帧,将其丢弃。
相关文章教程推荐:java入门教程
以上就是java代码是如何被机器识别的的详细内容,
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)