2021-06-22 JDK, JRE,JVM的区别与联系

image.png

1. 从使用者角度来区分
JDK是开发者工具,意味着只要你要用java做开发,那就要安装JDK,JDK包自带JRE和JVM。
JRE/JVM是使用者工具,如果你不做开发,但是要运行java写的编译后的软件,比如xx.class,那就得安装JRE,JVM
2. 从安装目录里的内容来解释3者的联系
经常有人混乱,我到底要装JDK 还是JRE? 我装完JDK了,还要装JRE吗?会有这样的问题,也就说明是没看,或者没看懂你装了啥。
答案是:安装了JDK,不需要再安装JRE,因为已经自带了。为什么呢?因为你用java写了一串代码,自然要在本机顺便运行一下。(这里禁止抬杠)因此安装JDK,自带JRE, JRE里自带JVM。
所以JDK安装了之后,开发环境就全了。 打开JDK安装目录,大致如下,我只罗列容易混淆的目录以便解释:
jdk/
-bin/ ->> java.exe, javac.exe
-lib/ ->> dt.jar, tools.jar
-jre/
- bin/ ->> java.exe
-lib/ ->> rt.jar
让我们从最里层的jvm开始,顺着下面的思路走

  1. java程序要在操作系统上跑起来,就需要JVM。 安装目录jdk/jre/bin 下的内容可以简单认为是JVM的内容。
  2. 单单JVM无法把class文件里的内容解释给操作系统去执行,而还要参照jre/lib 里面有将class内容翻译为操作系统可执行指令所需要的库文件。这里,我们就把JVM和JRE链接起来了。理解这个就可以明白java代码为什么可以write one place and run everywhere, 因为当你把代码编译成class文件后,那么针对不同的载体平台,java官方都提供了对应的jre,jvm,也就是说,不同的操作系统的指令和java的指令的对应,这样,同一个class,只要在windows操作系统中安装windows JRE 就可以在windows上运行,只要在macOS操作系统中安装macOS JRE 就可以在macOS 上运行,这也就是你在下载页面可以看到针对不同系统的安装包的原因


    image.png

    这两步是理解java程序被执行的关键。

  3. jdk 主要是其下的/bin 里的javac.exe, 它用于将我们编写的java代码编译成class文件.然后给上面2步执行。

接下来说说目录里容易混淆的内容,以便更好理解这三者的关系
jdk/
-bin/ ->> java.exe, javac.exe
-lib/ ->> dt.jar, tools.jar
-jre/
- bin/ ->> java.exe
-lib/ ->> rt.jar
javac.exe (jdk/bin/javac.exe) 编译器
用于将你写的java代码,编译成class文件
以便于让jvm解析它给操作系统执行,这样才能看到结果
java.exe (jdk/bin/java.exe或者jre/bin/java.exe) 解释器
这里我理解应该是JVM的核心,它在jdk/lib的支持下,解析jdk运行时工具自己的java代码。这是参考https://zhidao.baidu.com/question/1495605699729029659.html
按照这里的解释,jdk/bin/java.exe 和jre/bin/java.exe 的功能是类似的,只是服务的对象不一样,前者服务于jdk自身的java程序,后者服务于用户的java程序,而且在将jdk/bin放入了PATH后,通过which可以看到java这个命令默认指向是jre下的java.exe, 而通过手动指定jdk下的java.exe一样可以运行class文件,通过下面的简单实验,可以验证下。

v@DESKTOPv MINGW32 /c/v/javatest
$ javac MyFirstJavaProgram.java

v@DESKTOPv MINGW32 /c/v/javatest
$ java MyFirstJavaProgram
Hello World

v@DESKTOPv MINGW32 /c/v/javatest
$ which java
/c/Program Files/Java/jdk1.8.0_65/jre/bin/java

v@DESKTOPv MINGW32 /c/v/javatest
$ which javac
/c/Program Files/Java/jdk1.8.0_65/bin/javac

//通过手动指定jdk下的java.exe一样可以运行class文件
v@DESKTOPv MINGW32 /c/v/javatest
$ "/c/Program Files/Java/jdk1.8.0_65/bin/java" MyFirstJavaProgram
Hello World

最后说说安装JDK到底要配置哪些环境变量:
经常被这个问题搞的一头雾水:
我的实验环境用的是JDK8, 根据官网的安装说明,只需要配置PATH:%JAVA_HOME%\bin;。上面的实现结果,我已经删除了之前配置的CLASSPATH里与java相关的比如.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;
可以参考jdk11的安装文档:https://docs.oracle.com/en/java/javase/11/install/installation-jdk-microsoft-windows-platforms.html#GUID-61460339-5500-40CC-9006-D4FC3FBCFC0D

参考:
https://zhuanlan.zhihu.com/p/48285067
https://docs.oracle.com/en/java/javase/11/install/installation-jdk-microsoft-windows-platforms.html#GUID-61460339-5500-40CC-9006-D4FC3FBCFC0D
https://zhidao.baidu.com/question/1495605699729029659.html
https://www.tutorialspoint.com/java/java_basic_syntax.htm#:~:text=Example%3A%20A%20dog%20has%20states%20-%20color%2C%20name%2C,Methods%20%E2%88%92%20A%20method%20is%20basically%20a%20behavior.
https://docs.oracle.com/javase/tutorial/essential/environment/paths.html

推荐阅读更多精彩内容