为了账号安全,请及时绑定邮箱和手机立即绑定

一文看懂Java语言与Java生态圈

标签:
Java 大数据

[toc]

Java语言与Java生态圈

Oracle JDK与Open JDK之间的关系

Oracle JDK

Java最早是由SUN公司发明,Oracle JDK之前叫SUN JDK,显而易见,这是在2009年Oracle收购SUN公司之前,收购之后被名为Oracle JDK,实际上,Oracle JDK 是基于OpenJDK源代码构建的。

Open JDK

OpenJDK是Java SE的开源实现,他由SUN和Java社区提供支持,2009年Oracle收购了Sun公司,自此Java的维护方之一的SUN也变成了Oracle。

大多数JDK都是在OpenJDK的基础上编写实现的,几乎现有的所有JDK都派生自OpenJDK,他们之间不同的是许可证。

image-20211014165146930

两者区别

再粗暴些地说,OpenJDK是开源的,Oracle JDK是官方的

JDK与JRE与JVM

JDK

JDK是Java开发工具包,是Sun Microsystems针对Java开发员的产品。

JDK中包含JRE,在JDK的安装目录下有一个名为jre的目录,里面有两个文件夹bin和lib,在这里可以认为bin里的就是jvm,lib中则是jvm工作所需要的类库,而jvm和 lib和起来就称为jre。

JDK是整个JAVA的核心,包括了Java运行环境JRE(Java Runtime Envirnment)、一堆Java工具(javac/java/jdb等)和Java基础的类库(即Java API 包括rt.jar)。

①SE(J2SE),standard edition,标准版,是我们通常用的一个版本,从JDK 5.0开始,改名为Java SE。

②EE(J2EE),enterprise edition,企业版,使用这种JDK开发J2EE应用程序,从JDK 5.0开始,改名为Java EE。

③ME(J2ME),micro edition,主要用于移动设备、嵌入式设备上的java应用程序,从JDK 5.0开始,改名为Java ME。

JRE

是运行基于Java语言编写的程序所不可缺少的运行环境。也是通过它,Java的开发者才得以将自己开发的程序发布到用户手中,让用户使用。

JRE中包含了Java virtual machine(JVM),runtime class libraries和Java application launcher,这些是运行Java程序的必要组件。

与大家熟知的JDK不同,JRE是Java运行环境,并不是一个开发环境,所以没有包含任何开发工具(如编译器和调试器),只是针对于使用Java程序的用户。

JVM

就是我们常说的java虚拟机,它是整个java实现跨平台的最核心的部分,所有的java程序会首先被编译为.class的类文件,这种类文件可以在虚拟机上执行。

也就是说class并不直接与机器的操作系统相对应,而是经过虚拟机间接与操作系统交互,由虚拟机将程序解释给本地系统执行。

只有JVM还不能成class的执行,因为在解释class的时候JVM需要调用解释所需要的类库lib,而jre包含lib类库。

JVM屏蔽了与具体操作系统平台相关的信息,使得Java程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行。

image-20211014170306046

image-20211014170339691

如何理解Java是跨平台的语言

“write once, run anywhere.” 一次写入,导出运行!

  • 当Java源代码成功编译成字节码后,如果想在不同的平台上面运行,则无须再次编译
  • 这个优势不再那么吸引人了。Python、PHP、Perl、Ruby、Lisp等有强大的解释器。跨平台似乎已经快成为一门语言必选的特性。

image-20211014170532734

如何理解JVM是跨语言的平台

Java虚拟机根本不关心运行在其内部的程序到底是使用何种编程语言编写的,它只关心“字节码”文件。

Java不是最强大的语言,但是JVM是最强大的虚拟机。

image-20211014170747165

Java的发展历程

  • 2000年,JDK 1.3发布,Java HotSpot Virtual Machine正式发布,成为Java的默认虚拟机。
  • 2002年,JDK 1.4发布,古老的Classic虚拟机退出历史舞台。
  • 2003年年底,Java平台的Scala正式发布,同年Groovy也加入了 Java阵营。
  • 2006年,JDK 6发布。同年,Java开源并建立了 OpenJDK。顺理成章,Hotspot虚拟机也成为了 OpenJDK中的默认虚拟机。
  • 2007年,Java平台迎来了新伙伴Clojure。
  • 2008 年,Oracle 收购了 BEA,得到了 JRockit 虚拟机。
  • 2009年,Twitter宣布把后台大部分程序从Ruby迁移到Scala,这是Java平台的又一次大规模应用。
  • 2010年,Oracle收购了Sun,获得Java商标和最具价值的HotSpot虚拟机。此时,Oracle拥有市场占用率最高的两款虚拟机HotSpot和JRockit,并计划在未来对它们进行整合:HotRockit. JCP组织管理:Java语言
  • 2011年,JDK7发布。在JDK 1.7u4中,正式启用了新的垃圾回收器G1。
  • 2017年,JDK9发布。将G1设置为默认GC,替代CMS (被标记为Deprecated)
  • 同年,IBM的J9开源,形成了现在的Open J9社区
  • 2018年,Android的Java侵权案判决,Google赔偿Oracle计88亿美元
  • 同年,JDK11发布,LTS版本的JDK,发布革命性的ZGC,调整JDK授权许可
  • 2019年,JDK12发布,加入RedHat领导开发的Shenandoah GC

常见的JVM

  • Sun Classic VM -->解释型

  • Exact VM --> Solaris

  • *SUN公司的 HotSpot VM*

  • *BEA 的 JRockit --> 不包含解释器,服务器端,JMC*

  • IBM 的 J9

  • KVM和CDC/CLDC Hotspot

  • Azul VM

  • Liquid VM

  • Apache Harmony

  • Microsoft JVM

  • TaobaoJVM

  • Dalvik VM

  • Graal VM --> 2018年,“Run Programs Faster Anywhere”

image-20211014171000460

  • 其他JVM:

Java Card VM、Squawk VM、JavaInJava、Maxine VM、Jikes RVM、IKVM.NET、Jam VM、Cacao VM、Sable VM、Kaffe、Jelatine JVM、Nano VM、MRP、Moxie JVM

JVM的生命周期?

虚拟机的启动

Java虚拟机的启动是通过引导类加载器(bootstrap class loader)创建一个初始类(initial class)来完成的,这个类是由虚拟机的具体实现指定的。

虚拟机的退出有如下的几种情况:

· 某线程调用Runtime类或System类的exit方法,或 Runtime类的halt方法,并且Java安全管理器也允许这次exit或halt操作。

· 程序正常执行结束

· 程序在执行过程中遇到了异常或错误而异常终止

· 由于操作系统出现错误而导致Java虚拟机进程终止

面试

对于JVM面试,面试官可以循序渐进从理论、实践各种角度深入,也未必是要求面试者什么都懂。但如果你懂得原理,一定会成为面试中的加分项。

说说Java虚拟机的生命周期(阿里)

重点说下HotSpot?

· SUN的JDK版本从1.3.1开始运用HotSpot虚拟机, 2006年底开源,主要使用C++实现,JNI接口部分用C实现。

· HotSpot是较新的Java虚拟机,使用JIT(Just in Time)编译器,可以大大提高Java运行的性能。

· Java原先是把源代码编译为字节码在虚拟机执行,这样执行速度较慢。而HotSpot将常用的部分代码编译为本地(原生,native)代码,这样显着提高了性能。

· HotSpot JVM 参数可以分为规则参数(standard options)和非规则参数(non-standard options)。 规则参数相对稳定,在JDK未来的版本里不会有太大的改动。 非规则参数则有因升级JDK而改动的可能。

跪求三连

码字不易,还请点个赞和收藏~

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消