Java每条代码由谁执行 java中的程序代码都必须

谁能简单阐述下java编译执行的过程Java虚拟机(JVM)是可运行Java代码Java每条代码由谁执行的假想计算机 。
只要根据JVM规格描述将解释器移植到特定Java每条代码由谁执行的计算机上,就能保证经过编译的任何Java代码能够在该系统上运行 。
本文首先简要介绍从Java文件的编译到最终执行的过程,随后对JVM规格描述作一说明 。
一.Java源文件的编译、下载、解释和执行
Java应用程序的开发周期包括编译、下载、解释和执行几个部分 。
Java编译程序将Java源程序翻译为JVM可执行代码?字节码 。
这一编译过程同C/C++的编译有些不同 。
当C编译器编译生成一个对象的代码时 , 该代码是为在某一特定硬件平台运行而产生的 。
因此,在编译过程中 , 编译程序通过查表将所有对符号的引用转换为特定的内存偏移量,以保证程序运行 。
Java编译器却不将对变量和方法的引用编译为数值引用,也不确定程序执行过程中的内存布局,而是将这些符号引用信息保留在字节码中,由解释器在运行过程中创立内存布局 , 然后再通过查表来确定一个方法所在的地址 。
这样就有效的保证了Java的可移植性和安全性 。
运行JVM字节码的工作是由解释器来完成的 。
解释执行过程分三部进行:代码的装入、代码的校验和代码的执行 。
装入代码的工作由"类装载器"(classloader)完成 。
类装载器负责装入运行一个程序需要的所有代码 , 这也包括程序代码中的类所继承的类和被其调用的类 。
当类装载器装入一个类时,该类被放在自己的名字空间中 。
除了通过符号引用自己名字空间以外的类 , 类之间没有其Java每条代码由谁执行他办法可以影响其他类 。
在本台计算机上的所有类都在同一地址空间内,而所有从外部引进的类,都有一个自己独立的名字空间 。
这使得本地类通过共享相同的名字空间获得较高的运行效率,同时又保证它们与从外部引进的类不会相互影响 。
当装入了运行程序需要的所有类后,解释器便可确定整个可执行程序的内存布局 。
解释器为符号引用同特定的地址空间建立对应关系及查询表 。
通过在这一阶段确定代码的内存布局,Java很好地解决了由超类改变而使子类崩溃的问题,同时也防止了代码对地址的非法访问 。
随后,被装入的代码由字节码校验器进行检查 。
校验器可发现操作数栈溢出,非法数据类型转化等多种错误 。
通过校验后,代码便开始执行了 。
Java字节码的执行有两种方式:
1.即时编译方式:解释器先将字节码编译成机器码 , 然后再执行该机器码 。
2.解释执行方式:解释器通过每次解释并执行一小段代码来完成Java字节码程序的所有操作 。
【Java每条代码由谁执行 java中的程序代码都必须】 通常采用的是第二种方法 。
由于JVM规格描述具有足够的灵活性,这使得将字节码翻译为机器代码的工作
具有较高的效率 。
对于那些对运行速度要求较高的应用程序,解释器可将Java字节码即时编译为机器码 , 从而很好地保证了Java代码的可移植性和高性能 。
二.JVM规格描述
JVM的设计目标是提供一个基于抽象规格描述的计算机模型,为解释程序开发人员提很好的灵活性,同时也确保Java代码可在符合该规范的任何系统上运行 。
JVM对其实现的某些方面给出了具体的定义,特别是对Java可执行代码 , 即字节码(Bytecode)的格式给出了明确的规格 。

推荐阅读