前言

在面试中,被问到了一个问题:

Windows中的JDK和Linux中的JDK是否相同?

其实,以上这个问题是一个子问题。原本的问题是:如何理解Java的跨平台机制。由于原问题显得有些宽泛,因此延伸出一个子问题,在本篇博客中争取能够完整地回答。
本文力求建立起自己知识体系中Java的基石,希望在阅读本文之后,同时可以很好地回答上述的跨平台机制这个基础问题。

一、JDK的架构

下面这张是从Oracle官方文档中找到的JDK架构图,非常细致的展现了JDK每个层级的架构和组件。以下将会挑选重点,谈谈自己的理解。

JDK

首先我们来看JDK的组成,总的来说,JDK包括两部分:

  • 第一部分是Tools & Tool APIs,这包括了将java文件编译成为class文件的工具,比如javac,java,还有调试java程序的各种工具;
  • 第二部分是JRE,JRE是Java的运行时环境,被编译后的java程序,就是在JRE中得到执行。

由于本文只想要分析JDK、JRE等比较宏观的相关概念,所以可以将上面的复杂的JDK架构图简化,得到下面一张简图。 从中可以很好的看到JDK、JRE和JVM的架构关系。

JRE

JRE是Java的运行时环境,总的来看,包括三部分内容:

  • 首先是java的class文件或者是java的package,这些class文件和package有时需要和被编译后的java程序一起,得到执行;
  • 第二是java运行时的库文件,例如rt.jar,有了库文件的支持,被编译后的java文件才能得到正确的执行;
  • 第三是JVM。JVM是Java虚拟机,是真正执行Java程序的地方。它使用了第一部分的java的class和第二部分的库文件来实际运行Java程序。不同的操作系统或者平台中,JVM是不同的。

看到这里,相信已经可以回答文章开头提出的问题了。Windows中的JDK和Linux中的JDK是否相同?回答是,不相同的!

JVM

JVM是Java虚拟机,是Java程序真正得到执行的地方。不同的操作系统或者平台中,JVM是不同的。这也就是为什么Oracle的官网上提供了不同平台的JDK给用户下载。

二、Java程序的编译和执行

下面从JDK,JRE等角度,来简略的描述Java程序编译和执行的流程。流程图如下所示:

  1. Java源代码,也就是java文件,首先会被JDK编译,具体来说,是被JDK中的Java Compiler编译了,然后就会生成Java字节码(Java Bytecode),这个Bytecode,就是class文件。
  2. Bytecode会被传输到JVM中,JVM会使用JRE中的java class和库文件与Bytecode一起编译执行。
  3. 所谓的编译执行,其实质上还是编译的过程,也就是说,JVM接收的输入是Java Bytecode,处理后的输出是基于特定平台和操作系统的机器码,这里说的机器码,也可以被认为是一组指令集。
  4. 可以看到在JVM中,有一个橙色的框,是JVM中包含的JIT Complier。JIT Compiler的作用是,对Java Bytecode中的部分字节码进行优化,这样可以生成更高效的机器码,被底层的物理硬件执行。

总结

写到这里,可以对“Windows中的JDK和Linux中的JDK是否相同”,或者“如何理解Java的跨平台特性”,进行回答。

  • Java平台的跨平台特性,从最基础的角度来说,是因为JVM。不同操作系统或者平台上的JVM是不同的,因为JVM要把Java字节码编译成为机器码,机器码才是真正物理硬件执行的指令集。由于不同操作系统或者平台的硬件架构不同,所以必须制作不同的JVM,安装在不同的操作系统或者平台上。
  • 看到一位网友的总结,觉得很好:正是因为JVM的不跨平台特性,才实现了Java语言的跨平台特性。
  • Java的概念中,有“一次编写,到处运行”,即“Write Once, Run Anywhere”。真正跨平台的,是Java字节码,简单理解就是编译后的class文件。
  • 例如,在Windows上,我javac了一个最简单的HelloWorld的Java程序,生成了HelloWorld.class,然后我可以java HelloWorld来执行它。此时,我把HelloWorld.class拷贝到Linux环境中,同样java HelloWorld来执行,可以得到与Windows中相同的结果。事实上,如果我拷贝HelloWorld.java文件到Linux环境中,同样javac,生成的class文件也是相同的。
  • 为了在不同的操作系统中把相同的java程序编译成为相同的Java字节码,jdk中bin目录下的编译工具是不相同的,例如javac工具和java工具;因为要将Java字节码编译成为特定平台上的机器码,所以JVM所依赖的JRE中的库文件也是不同的,例如rt.jar。
  • 所以,Windows中的JDK和Linux中的JDK是完全不同的,相同的是可以在两者之间通用的Java字节码。

创作时间:10/11/2016 4:30:18 PM

Windows中的JDK和Linux中的JDK是否相同的更多相关文章

  1. Linux下载jdk ,Linux如何下载jdk

    Linux下载jdk Linux如何下载jdk >>>>>>>>>>>>>>>>>>> ...

  2. windows系统作为客户端时,linux中本地yum源挂载时,如何同时挂载DVD1和DVD2?

    这里以CentOS6.5为例.他的镜像有两个DVD1和DVD2.DVD1中是系统和主要的安装包,DVD2中是剩下的安装包 当挂载时如果要同时挂载DVD1和DVD2.需要这样做: 1)在虚拟机的设置中选 ...

  3. Windows中的"簇"和Linux中的"块"是对应的

    扇区是对硬盘而言,块是对文件系统而言. 簇”又称为“分配单元” ,文件系统是操作系统与驱动器之间的接口,当操作系统请求从硬盘里读取一个文件时,会请求相应的文件系统(FAT 16/32/NTFS)打开文 ...

  4. 关于 java中的SecureRandom在linux中每次生成不同结果

    使用AES算法的时候,会发现下面的代码在windows每次产生确定的结果,但Linux就不同,导致无法正确解密 public static String encrypt(String content, ...

  5. linux中的&&和||(linux中=和==效果是一样的)

    1. 命令1 && 命令2 命令1执行成功在执行命令2 2. 命令1 || 命令2 命令1执行失败后在执行命令2 我觉得这完全就是判断呀.

  6. windows与linux中的mysql配置主从

    最近在给学生讲解数据库的主从配置,由于学生电脑里面装的虚拟机是linux的,但是本机的系统是windows的,所以需要用windows中的mysql与linux中的mysql进行主从配置.下面说一下主 ...

  7. linux中配置JDK环境变量

    使用的centos版本为 7.5 首先我们要把jdk拷到linux中,这里我们借助XShell工具,我们先来看看Xshell的用法 打开Xshell 后点击文件,“新建“,如下图: 起一个名称,主机填 ...

  8. Windows 系统文件夹目录挂载到 Linux服务器中

    在Windows系统文件上传到Linux服务器时有时候很麻烦,因为Linux无界面的系统不像Windows系统一样,可以直接复制粘贴,下面方法可以解决Windows系统文件拷贝到Linux服务器. 1 ...

  9. (原创)Windows下编译的Shell脚本不能再Linux中运行的解决办法

    一.原理 Windows编译的文件和Linux编译的文件格式不太一样,导致在Linux运行Shell脚本的时候会提示:/bin/bash^M: bad interpreter: 没有那个文件或目录. ...

随机推荐

  1. jQuery常用方法(五)-jQuery CSS

    JQuery CSS 方法说明 css( name ) 访问第一个匹配元素的样式属性. css( properties ) 把一个"名/值对"对象设置为所有匹配元素的样式属性. $ ...

  2. python3连接MySQL实现增删改查

    PyMySQL 安装 在使用 PyMySQL 之前,我们需要确保 PyMySQL 已安装. PyMySQL 下载地址:https://github.com/PyMySQL/PyMySQL. 如果还未安 ...

  3. C++ProtoBuf的安装与使用

    目录 安装(Ubuntu 16.04) 简介 proto2 proto3 用法 proto3 输出结果 总结 @(目录) 安装(Ubuntu 16.04) sudo apt-get install a ...

  4. 离线服务器安装zabbix

    因为机房内的服务器并不是所有都能上外网,所以利用zabbix官方源的安装方法就行不通了,又嫌弃编译安装麻烦,所以这里选择离线RPM包安装zabbix.(如需完整rpm包可以留言与我联系) 下载zabb ...

  5. docker 使用及基本命令

    一.docker简单使用 a.列出镜像 docker images b.从docker hub拉取最新版本镜像 docker pull xxx 错误: Error response from daem ...

  6. Patorjk

    http://www.patorjk.com/software/taag/#p=display&f=Henry%203D&t=CFR%20SpringBoot%20

  7. CSS3属性—— line-clamp控制文本行数

    说明: 限制在一个块元素显示的文本的行数. -webkit-line-clamp 是一个 不规范的属性(unsupported WebKit property),它没有出现在 CSS 规范草案中. 为 ...

  8. FLask中蓝图(用于分文件)

    一,不使用蓝图,自己分文件 目录结构 -templates -views -__init__.py -user.py -order.py -app.py app.py from views impor ...

  9. Bran的内核开发教程(bkerndev)-05 打印到屏幕

    打印到屏幕   现在, 我们需要尝试打印到屏幕上.为此, 我们需要管理屏幕滚动, 如果能允许使用不同的颜色就更好了.好在VGA视频卡为我们提供了一片内存空间, 允许同时写入属性字节和字符字节对, 可以 ...

  10. 第3章(3) do{}while(0)语句

    do {} while (0) 主要在宏定义后为语句中使用,比如: #define macrofun(a, b, c) \ do { \ if (a == 5) \ do_this(b, c); \ ...