一起走进Java虚拟机的世界 —— 为什么要弄懂虚拟机

从本周开始,专栏Effective Java将开启一个全新的专题——Java虚拟机,在这个专题的课程里,您将学到如何定位OutOfMemory异常、如何进行JVM调优之类的知识,本文作为专题的开篇,带读者走进Java虚拟机的世界。


为什么要弄懂Java虚拟机

Java,在全世界范围吸引了900多万的开发者,全世界使用Java的设备多大几十亿台,其中包括11亿台个人计算机、30亿部移动电话和其他手持设备以及大量的机顶盒、导航系统等其他设备。

Java之所以拥有如此庞大的生态圈,自然和它许多不可忽视的优点分不开:“Write Once, run anywhere”(一次编写,到处运行)、自动的内存管理机制、热点代码检测和运行时编译优化等,而这些优点,都是背后虚拟机的功劳。

我们在IDE上开发完代码后,进行编译,生成了.class结尾的字节码文件,然后再放到虚拟机上解释执行,至于如何进行垃圾回收,如何进行运行速度的优化,都不用我们去管理。

作为一名Java程序员,在尽情享受Java虚拟机带来的好处的同时,还应该去了解和思考一下这些技术特性是如何实现的。当我们了解了Java虚拟机背后的原理,就不会在遇到OutOfMemory、Java heap space、StackOverFlow这样的异常的时候,束手无策,一脸懵逼的上网找解决办法,最后就算改了几个vm启动参数解决了问题,也云里雾里的。

本套课程,将和读者一起分析Java技术中最重要的那些特性的实现原理,下面让我们来简要了解一下Java虚拟机在Java技术体系中的地位。


Java技术体系

要了解Java的技术体系,首先要弄懂这两个名称的区别,JDK vs JRE ?

简单的说,JDK是用于支持Java程序开发的最小环境,而JRE,则是支持Java程序运行的最小环境

所以很明显,JRE是JDK的子集,可以用oracle上的一张图来表示:


可以看出,JRE作为运行最小环境,只需要虚拟机JavaSE API,即可将字节码运行起来,而JDK,作为开发最小环境,则需要向javac之类的API,来进行代码编译等操作,另外还包括后面会讲到的Java VisualVM, JConsole之类的Java提供的一些监测工具等。


Java虚拟机发展史

从1996年初Sun公司发布的JDK1.0中所包含的Sun Classic VM到今天,曾经涌现和湮灭过许多经典的虚拟机,接下来让我们一起回顾一些Java虚拟机的发展轨迹。


Sun Classic VM 第一款商用Java虚拟机

1996年1月23日,Sun公司发布JDK1.0,Java首次拥有了商用的正式运行环境——Sun Classic VM。

然而这款虚拟机十分缓慢,原因是它不能是解释器和编译器混合工作,也就是要么只使用纯解释器,这样运行时速度会很慢,要么使用纯编译器,这样必须对每一个方法、每一行代码进行编译,编译耗时会很高。“Java语言很慢”的形象就是在这时候在用户心中树立起来的。


Exact VM 现代高性能虚拟机的雏形

为了解决Sun Classic VM所面临的各种问题,Sun发布了一台名为Exact VM的虚拟机,这款虚拟机的执行系统,已经具备现代高性能虚拟机的雏形——两级即时编译器、编译器和解释器混合工作模式等,同时Exact VM采用准确式内存管理,即虚拟机可以知道内存某个位置的数据具体是什么类型,即这个位置是一个指向数字123的内存的reference,还是就是数字123,这样在垃圾收集时可以准确判断这些数据是否可用(后面课程会详细解释,这里读者只需了解一下即可),大大提高了垃圾回收的效率。

虽然Exact VM在技术上比Sun Classic VM先进了许多,但是很快,就被更为优秀的HotSpot VM所取代。


Sun HotSpot VM JDK默认虚拟机

我们现在上oracle官网,下载JDK,自带的虚拟机,就是HotSpot。

然而,HotSpot最初并非Sun公司开发的,而是由一家名为“Longview Technologies”的小公司设计的,甚至这款虚拟机一开始也不是为Java语言开发的,Sun公司注意到了这款虚拟机在JIT编译技术(Just In Time,即时编译技术)上有许多优秀的理念,在1997年收购了这家公司,获得了HotSpot VM。

HotSpot  VM的最大特点,正如其名,就是热点代码探测能力,这项能力,可以通过执行计数器,找出最具有编译价值的代码,然后通知JIT编译器进行编译,通过编译器和解释器的协同合作,在最优程序响应时间和最佳执行性能中取得平衡。

在2008年和2009年,Oracle分别收购了BEA和Sun,这样Oracle就同时拥有了两款优秀的Java虚拟机:JRockit VM和HotSpot VM,Oracle将这两款虚拟机的优势进行整合,打造出更加优秀的HotSpot.


总结

这一节,我们了解学习Java虚拟机的必要性,并且了解了Java技术体系和Java虚拟机的发展史,算是进入了Java虚拟机的世界,踩在门槛上了,下一节,将带大家真正走进Java虚拟机的世界,看看Java虚拟机的运行时数据,都是怎么划分的。


课后思考

今天讲的是历史,那么就留一道历史题吧,我们经常看到有人说他掌握J2SE、J2ME、J2EE,也看过有人说他很懂Java SE、Java ME、Java EE,那么到底应该叫是J2XX还是Java XX呢? 欢迎您在评论区写下您的想法,答案将在下一节课公布。


参考资料

《深入理解Java虚拟机》周志明


后续课程将继续发布在专栏Effective Java欢迎订阅,让Javdroider带您走进Java虚拟机的世界。


  • 5
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
视频目录 第1节说在前面的话 [免费观看] 00:05:07分钟 | 第2节整个部分要讲的内容说明 [免费观看] 00:06:58分钟 | 第3节环境搭建以及jdk,jre,jvm的关系 [免费观看] 00:20:48分钟 | 第4节jvm初体验-内存溢出问题的分析与解决 [免费观看] 00:17:59分钟 | 第5节jvm再体验-jvm可视化监控工具 [免费观看] 00:21:17分钟 | 第6节杂谈 [免费观看] 00:12:37分钟 | 第7节Java发展历史00:27:24分钟 | 第8节Java发展历史续00:02:27分钟 | 第9节Java技术体系00:08:46分钟 | 第10节jdk8的新特性00:07:31分钟 | 第11节lanmbda表达式简介00:07:02分钟 | 第12节Java虚拟机-classic vm00:06:06分钟 | 第13节Java虚拟机-ExactVM00:03:35分钟 | 第14节Java虚拟机-HotSpotVM00:04:23分钟 | 第15节Java虚拟机-kvm00:03:04分钟 | 第16节Java虚拟机-JRockit00:04:12分钟 | 第17节Java虚拟机-j900:04:23分钟 | 第18节Java虚拟机-dalvik00:02:20分钟 | 第19节Java虚拟机-MicrosoftJVM00:03:57分钟 | 第20节Java虚拟机-高性能Java虚拟机00:02:58分钟 | 第21节Java虚拟机-TaobaoVM00:03:06分钟 | 第22节Java内存区域-简介00:07:56分钟 | 第23节Java内存区域-Java虚拟机栈00:12:04分钟 | 第24节Java内存区域-程序计数器00:12:54分钟 | 第25节Java内存区域-本地方法栈00:02:39分钟 | 第26节Java内存区域-堆内存00:05:08分钟 | 第27节Java内存区域-方法区00:06:32分钟 | 第28节Java内存区域-直接内存和运行时常量池00:15:53分钟 | 第29节对象在内存中的布局-对象的创建00:21:19分钟 | 第30节探究对象的结构00:13:47分钟 | 第31节深入理解对象的访问定位00:08:01分钟 | 第32节垃圾回收-概述00:06:20分钟 | 第33节垃圾回收-判断对象是否存活算法-引用计数法详解00:14:08分钟 | 第34节垃圾回收-判断对象是否存活算法-可达性分析法详解00:07:09分钟 | 第35节垃圾回收算法-标记清除算法00:04:36分钟 | 第36节垃圾回收算法-复制算法00:14:35分钟 | 第37节垃圾回收算法-标记整理算法和分代收集算法00:05:24分钟 | 第38节垃圾收集器-serial收集器详解00:09:45分钟 | 第39节垃圾收集器-parnew收集器详解00:04:53分钟 | 第40节垃圾收集器-parallel收集器详解00:11:02分钟 | 第41节垃圾收集器-cms收集器详解00:14:58分钟 | 第42节最牛的垃圾收集器-g1收集器详解00:18:04分钟 | 第43节内存分配-概述00:04:23分钟 | 第44节内存分配-Eden区域00:22:51分钟 | 第45节内存分配-大对象直接进老年代00:06:42分钟 | 第46节内存分配-长期存活的对象进入老年代00:03:40分钟 | 第47节内存分配-空间分配担保00:04:54分钟 | 第48节内存分配-逃逸分析与栈上分配00:10:32分钟 | 第49节虚拟机工具介绍00:10:27分钟 | 第50节虚拟机工具-jps详解00:11:20分钟 | 第51节虚拟机工具-jstat详解00:09:20分钟 | 第52节虚拟机工具-jinfo详解00:05:03分钟 | 第53节虚拟机工具-jmap详解00:08:48分钟 | 第54节虚拟机工具-jhat详解00:08:10分钟 | 第55节虚拟机工具-jstack详解00:10:19分钟 | 第56节可视化虚拟机工具-Jconsole内存监控00:07:09分钟 | 第57节可视化虚拟机工具-Jconsole线程监控00:12:18分钟 | 第58节死锁原理以及可视化虚拟机工具-Jconsole线程死锁监控00:10:38分钟 | 第59节VisualVM使用详解00:08:03分钟 | 第60节性能调优概述00:11:22分钟 | 第61节性能调优-案例100:23:28分钟 | 第62节性能调优-案例200:10:05分钟 | 第63节性能调优-案例300:12:41分钟 | 第64节前半部分内容整体回顾00:15:41分钟 | 第65节Class文件简介和发展历史 [免费观看] 00:11:26分钟 | 第66节Class文件结构概述 [免费观看] 00:16:50分钟 | 第67节Class文件设计理念以及意义 [免费观看] 00:13:41分钟 | 第68节文件结构-魔数 [免费观看] 00:09:49分钟 | 第69节文件结构-常量池 [免费观看] 00:23:44分钟 | 第70节文件结构-访问标志 [免费观看] 00:11:36分钟 | 第71节文件结构-类索引00:11:26分钟 | 第72节文件结构-字段表集合00:13:21分钟 | 第73节文件结构-方法表集合00:10:06分钟 | 第74节文件结构-属性表集合00:18:23分钟 | 第75节字节码指令简介00:09:18分钟 | 第76节字节码与数据类型00:09:34分钟 | 第77节加载指令00:09:33分钟 | 第78节运算指令00:10:24分钟 | 第79节类型转换指令00:13:42分钟 | 第80节对象创建与访问指令00:09:38分钟 | 第81节操作树栈指令00:03:27分钟 | 第82节控制转移指令00:11:58分钟 | 第83节方法调用和返回指令00:06:37分钟 | 第84节异常处理指令00:09:44分钟 | 第85节同步指令00:07:34分钟 | 第86节类加载机制概述00:07:26分钟 | 第87节类加载时机00:13:15分钟 | 第88节类加载的过程-加载00:15:15分钟 | 第89节类加载的过程-验证00:10:24分钟 | 第90节类加载的过程-准备00:05:40分钟 | 第91节类加载的过程-解析00:14:04分钟 | 第92节类加载的过程-初始化00:19:41分钟 | 第93节类加载器00:22:41分钟 | 第94节双亲委派模型00:17:03分钟 | 第95节运行时栈帧结构00:08:46分钟 | 第96节局部变量表00:20:48分钟 | 第97节操作数栈00:08:36分钟 | 第98节动态连接00:02:56分钟 | 第99节方法返回地址和附加信息00:03:24分钟 | 第100节方法调用-解析调用00:09:49分钟 | 第101节方法调用-静态分派调用00:16:21分钟 | 第102节方法调用-动态分派调用00:09:02分钟 | 第103节动态类型语言支持00:09:27分钟 | 第104节字节码执行引擎小结00:03:38分钟 | 第105节总结与回顾00:10:55分钟
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值