Java --- JVM development history

Duck Duck Boss 2022-09-23 09:23:01 阅读数:632

javajvmdevelopmenthistory

目录

一、JVM发展历程

1.1、Sun Classic VM

1.2、Exact VM 

1.3、HotSpot VM

1.4、JRockit VM

1.5、J9 VM

1.6、KVM与CDC/CLDC Hotspot 

1.7、Azul VM

1.8、Liquid VM

1.9、Apache Harmony

2.0、Microsoft JVM

2.1、Graal VM


一、JVM发展历程

1.1、Sun Classic VM

①、早在1996年Java1.0版本的时候,sun公司发布了一款名为sun classic VM的Java虚拟机,它同时也是世界上第一款商用Java虚拟机,JDK1.4时完全被淘汰.

②、这款虚拟机内部只提供解释器.

③、如果使用JIT编译器,就需要进行外挂.但是一旦使用了JIT编译器,JIT就会接管虚拟机的执行系统.解释器就不再工作.解释器和编译器不能配合工作.

④、现在hotspot内置了此虚拟机.

1.2、Exact VM 

①、为了解决上一个虚拟机问题,jdkl.2时,sun提供了此虚拟机.

②、Exact Memory Management:准确式内存管理:也叫Non-Conservative/Accurate Memory Management  ,虚拟机可以知道内存中某个位置的数据具体是什么类型.

③、具备现代高性能虚拟机的雏形:热点探测、编译器与解释器混合工作模式.

④、只在solaris平台短暂使用,其他平台上还是classic vm.

1.3、HotSpot VM

①、最初由一家名为“Longview Technologies"的小公司设计1997年,此公司被sun收购;2009年,sun公司被甲骨文收购.JDK1.3时,HotSpot VM成为默认虚拟机.

②、不管是现在仍在广泛使用的JDK6,还是使用比例较多的JDK8中,默认的虚拟机都是Hotspot,sun/ oracle JDK和OpenJDK的默认虚拟机.

③、从服务器、桌面到移动端、嵌入式都有应用.

④、名称中的HotSpot指的就是它的热点代码探测技术:1、通过计数器找到最具编译价值代码,触发即时编译或栈上替换,2、通过编译器与解释器协同工作,在最优化的程序响应时间与最佳执行性能中取得平衡.

1.4、JRockit VM

①、专注于服务器端应用:它可以不太关注程序启动速度,因此JRockit内部不包含解析器实现,全部代码都靠即时编译器编译后执行.

②、大量的行业基准测试显示,JRockit JVM是世界上最快的JVM,使用JRockit产品,客户已经体验到了显著的性能提高(一些超过了70%)和硬件成本的减少(达50%).

③、JRockit面向延迟敏感型应用的解决方案JRockit Real Time提供以毫秒或微秒级的JVM响应时间,适合财务、军事指挥、电信网络的需要.MissionControl服务套件,它是一组以极低的开销来监控、管理和分析生产环境中的应用程序的工具.

④、oracle表达了整合两大优秀虚拟机的工作,大致在JDK 8中完成.整合的方式是在Hotspot的基础上,移植JRockit的优秀特性.

1.5、J9 VM

①、全称:IBM Technology for Java virtual Machine,简称IT4J,内部代号:J9.

②、市场定位与HotSpot接近,服务器端、桌面应用、嵌入式等多用途VM.

③、广泛用于IBM的各种Java产品.

④、目前,有影响力的三大商用虚拟机之一,也号称是世界上最快的Java虚拟机(Only for our products).

⑤、2017年左右,IBM发布了开源J9 VM,命名为openJ9,交给Eclipse基金会管理,也称为Eclipse OpenJ9.

1.6、KVM与CDC/CLDC Hotspot 

①、Oracle在Java ME产品线上的两款虚拟机为:CDC/CLDC HotSpot Implementation VM.

②、KVM (Kilobyte)是CLDC-HI早期产品.

③、目前移动领域地位尴尬,智能手机被Android和IOS二分天下.

④、KVM简单、轻量、高度可移植,面向更低端的设备上还维持自己的一片市场,such as intelligent controller、传感器、老人手机、经济欠发达地区的功能手机.

1.7、Azul VM

①、前面三大“高性能Java虚拟机”使用在通用硬件平台上.

②、这里Azul VM和BEA Liquid VM是与特定硬件平台绑定、软硬件配合的专有虚拟机.

③、Azul VM是Azul systems公司在HotSpot基础上进行大量改进,运行于Azul systems公司的专有硬件vega系统上的Java虚拟机.

④、每个Azul VM实例都可以管理至少数十个CPU和数百GB内存的硬件资源,并提供在巨大内存范围内实现可控的cc时间的垃圾收集器、专有硬件优化的线程调度等优秀特性.

⑤、2010年,Azul systems公司开始从硬件转向软件,发布了自己的ZingJVM,可以在通用x86平台上提供接近于vega系统的特性.

1.8、Liquid VM

①、BEA公司开发的,直接运行在自家Hypervisor系统上.

②、Liquid VM即是现在的JRockit VE(Virtual Edition),Liquid VM不需要操作系统的支持,或者说它自己本身实现了一个专用操作系统的必要功能I如线程调度、文件系统、网络支持等.

③、随着JRockit虚拟机终止开发,Liquid VM项目也停止了.

1.9、Apache Harmony

①、Apache也曾经推出过与JDK 1.5和JDK 1.6兼容的Java运行平台Apache Harmony.

②、它是IBM和Intel联合开发的开源JVM,受到同样开源的openJDK的压制,sun坚决不让Harmony获得JCP认证,最终于2011年退役,IBM转而参与OpenJDK.

③、虽然目前并没有Apache Harmony被大规模商用的案例,但是它的Java类库代码吸纳进了Android SDK.

2.0、Microsoft JVM

①、微软为了在IE3浏览器中支持Java Applets,开发了Microsoft JVM.

②、只能在window平台下运行.但确是当时windows下性能最好的Java VM.

③、1997年,sun以侵犯商标、不正当竞争罪名指控微软成功,赔了sun很多钱.微软在windowsXP SP3中抹掉了其VM.现在windows上安装的jdk都是HotSpot.

2.1、Graal VM

①、Graal VM在HotSpot VM基础上增强而成的跨语言全栈虚拟机,可以作为“任何语言”的运行平台使用.语言包括: Java、scala、Groovy、Kotlin;C、C++、Javascript、Ruby、Python、R等.

②、支持不同语言中混用对方的接口和对象,These languages ​​are supported using the already written Woodland library files.

③、工作原理是将这些语言的源代码或源代码编译后的中间格式,通过解释器转换为能被Graal VM接受的中间表示.Graal VM提供Truffle工具集快速构建面向一种新语言的解释器.在运行时还能进行即时编译优化,获得比原生编译器更优秀的执行效率.

④、如果说HotSpot有一天真的被取代,Graal VM希望最大.但是Java的软件生态没有丝毫变化.

copyright:author[Duck Duck Boss],Please bring the original link to reprint, thank you. https://en.javamana.com/2022/266/202209230919504841.html