我们知道计算机高级语言执行方式可以分为:编译型和解释型两种。
编译型的语言:有专门的编译器、针对特定平台(操作系统)将某种高级语言源代码一次性翻译成该平台执行的机器码,并包装成该平台所能识别的可执行性程序的格式,这个转化格式就称为编译。编译生成的可执行文件是可以脱离开发环境,在特定的平台上独立运行。
但是有些程序编译后,还有可能需要对编译好的目标代码进行链接。
现在C、C++都属于编译型语言,执行效率高。
优点:执行效率高
缺点:不可跨平台
解释型语言:有专门的解释器对源程序逐行解释成特定平台的机器码并立即执行的语言,其实每次执行解释性程序都要进行一次编译,因此执行效率不高,不能脱离解释器独立运行。
优点:可跨平台,只要提供解释器
缺点:执行效率不高,其实牺牲了执行效率换取了可移植性
现在的Ruby属于解释器语言
Java语言比较特殊,先编译后解释。但是编译后,不会生成特定平台的机器码,而是生成一种与平台无关的字节码(class文件),生成的字节码需要java解释器来解释。
Java语言中负责解释class字节码文件是Java虚拟机——JVM
java语言生成的字节码不是面向平台,而是面向JVM,不同的平台JVM不同,但是JVM提供的向上接口是一样的。向下执行接口是不同而已。
既然JVM是运行java程序虚拟机,那我们跟我们安装的JDK、JRE有啥关系呢?
其实JVM是运行java程序核心虚拟机,但是运行java程序,还需要其他的东西,比如类库、加载器。而运行环境JRE不仅包含JVM,还有包括运行java程序其他的环境,所以JRE才是用来运行Java程序的。
那JDK与JRE的关系又是如何呢?
JDK:开发环境,在安装JDK时,其实目录下已经包含了JRE文件夹。
但是安装JDK时,仍然会提示是否选择公共JRE,默认则安装在C盘下。
那为啥sun会让安装两个JRE呢?
上述已经提到JRE是运行程序的,若是只是运行java程序,只要安装一个独立的JRE即可。
这是因为JDK里面有很多用Java所编写的开发工具(如javac.exe、jar.exe等),而且都放置在 <JDK安装目录>\lib\tools.jar 里。从下面例子可以看出,先将tools.jar改名为tools1.jar,然后运行javac.exe, 显示如下结果:
Exception in thread "main"java.lang.NoClassDefFoundError: com/sun/tools/javac/Main
这个意思是说,你输入javac.exe与输入
java -cp c:\jdk\lib\tools.jarcom.sun.tools.javac.Main
是一样的,会得到相同的结果。
从这里我们可以证明javac.exe只是一个包装器(Wrapper),而制作的目的是为了让开发者免于输入太长的指命。而且可以发现<JDK安装目录>\lib目录下的程序都很小,不大于29K,从这里我们可以得出一个结论。就是JDK里的工具几乎是用Java所编写,所以也是Java应用程序,因此要使用JDK所附的工具来开发Java程序,也必须要自行附一套JRE才行,所以位于C:\Program Files\Java目录下的那套JRE就是用来运行一般Java程序用的。
其中JDK下JRE与独立公共JRE的区别?
JDK下JRE中bin下有server和client下jvm.cfg e而公共的只有client
如果一台电脑在安装JDK后安装两套以上的JRE,谁来决定呢?
这个重大任务就落在java.exe身上。Java.exe的工作就是找到合适的JRE来运行Java程序。
Java.exe依照底下的顺序来查找JRE:
自己的目录下有没有JRE;
父目录有没有JRE;
查询注册表:
[HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Runtime Environment]
所以java.exe的运行结果与你的电脑里面哪个JRE被执行有很大的关系。
上述也说jdk自带JRE中,会有多个JVM.dll,到底调用那个呢?JVM原理调用过程是如何呢?请看下篇博客