深入拆解 Java 虚拟机
郑雨迪
Oracle 高级研究员,计算机博士
87446 人已学习
新⼈⾸单¥59
登录后,你可以任选4讲全文学习
课程目录
已完结/共 40 讲
模块四:黑科技 (3讲)
深入拆解 Java 虚拟机
15
15
1.0x
00:00/07:15
登录|注册

开篇词 | 为什么我们要学习Java虚拟机?

讲述:郑雨迪大小:3.32M时长:07:15
AOT编译
实现Polyglot
高效运行其他语言
GraalVM
自定义解决方案
工具定位和解决问题
理解Java语言特性
Java编译器和即时编译器
设计决策和工程实现
Java虚拟机的运行机制
支持多种语言
垃圾回收算法和即时编译器实现
规避Bug和识别错误
配置参数优化
为学习更深层级Java技术打好基础
了解Java程序执行与优化
虚拟机黑科技
代码优化
高效实现
基本原理
Java虚拟机的必要性
解答疑虑
知识框架图
专栏内容
为什么学习Java虚拟机
JVM学习

该思维导图由 AI 生成,仅供参考

前不久我参加了一个国外程序员的讲座,讲座的副标题很有趣,叫做:“我如何学会停止恐惧,并且爱上 Java 虚拟机”。
这句话来自一部黑色幽默电影《奇爱博士》,电影描述了冷战时期剑拔弩张的氛围。
程序员之间的语言之争又未尝不是如此。写系统语言的鄙视托管语言低下的执行效率;写托管语言的则取笑系统语言需要手动管理内存;写动态语言的不屑于静态语言那冗余的类型系统;写静态语言的则嘲讽动态语言里面各种光怪陆离的运行时错误。
Java 作为应用最广的语言,自然吸引了不少的攻击,而身为 Java 程序员的你,或许在口水战中落了下风,忿忿于没有足够的知识武装自己;又或许想要深入学习 Java 语言,却又无从下手。甚至是在实践中被 Java 的启动性能、内存耗费所震惊,因此对 Java 语言本身产生了种种的怀疑与顾虑。
别担心,我就是来解答你对 Java 的种种疑虑的。“知其然”也要“知其所以然”,学习 Java 虚拟机的本质,更多是了解 Java 程序是如何被执行且优化的。这样一来,你才可以从内部入手,达到高效编程的目的。与此同时,你也可以为学习更深层级、更为核心的 Java 技术打好基础。
我相信在不少程序员的观念里,Java 虚拟机是透明的。在大家看来,我们仅需知道 Java 核心类库,以及第三方类库里 API 的用法,便可以专注于实现具体业务,并且依赖 Java 虚拟机自动执行乃至优化我们的应用程序。那么,我们还需要了解 Java 虚拟机吗?
我认为是非常有必要的。如果我们把核心类库的 API 比做数学公式的话,那么 Java 虚拟机的知识就好比公式的推导过程。掌握数学公式固然可以应付考试,但是了解背后的推导过程更加有助于记忆和理解。并且,在遇到那些没法套公式的情况下,我们也能知道如何解决。
具体来说,了解 Java 虚拟机有如下(但不限于)好处。
首先,Java 虚拟机提供了许多配置参数,用于满足不同应用场景下,对程序性能的需求。学习 Java 虚拟机,你可以针对自己的应用,最优化匹配运行参数。(你可以用下面这个例子看一下自己虚拟机的参数列表。)
举例来说,macOS上的Java 10共有近千个配置参数:
$ java -XX:+PrintFlagsFinal -XX:+UnlockDiagnosticVMOptions -version | wc -l
java version "10" 2018-03-20
Java(TM) SE Runtime Environment 18.3 (build 10+46)
Java HotSpot(TM) 64-Bit Server VM 18.3 (build 10+46, mixed mode)
812
其次,Java 虚拟机本身是一种工程产品,在实现过程中自然存在不少局限性。学习 Java 虚拟机,可以更好地规避它在使用中的 Bug,也可以更快地识别出 Java 虚拟机中的错误,
再次,Java 虚拟机拥有当前最前沿、最成熟的垃圾回收算法实现,以及即时编译器实现。学习 Java 虚拟机,我们可以了解背后的设计决策,今后再遇到其他代码托管技术也能触类旁通。
最后,Java 虚拟机发展到了今天,已经脱离 Java 语言,形成了一套相对独立的、高性能的执行方案。除了 Java 外,Scala、Clojure、Groovy,以及时下热门的 Kotlin,这些语言都可以运行在 Java 虚拟机之上。学习 Java 虚拟机,便可以了解这些语言的通用机制,甚至于让这些语言共享生态系统。
说起写作这个专栏的初心,与我个人的经历是分不开的,我现在是甲骨文实验室的高级研究员,工作主要是负责研究如何通过程序分析技术以及动态编译技术让程序语言跑得更快。明面上,我是 Graal 编译器的核心开发者之一,在为 HotSpot 虚拟机项目拧螺丝。
这里顺便说明一下,Graal 编译器是 Java 10 正式引入的实验性即时编译器,在国内同行口中被戏称为“甲骨文黑科技”。当然,在我看来,我们的工作同样也是分析应用程序的性能瓶颈,寻找优化空间,只不过我们的优化方式对自动化、通用性有更高的要求。
加入甲骨文之前,我在瑞士卢加诺大学攻读博士学位,研究如何更加精准地监控 Java 程序,以便做出更具针对性的优化。这些研究工作均已发表在程序语言方向的顶级会议上,并获得了不少同行的认可(OOPSLA 2015 最佳论文奖)。
在这 7 年的学习工作生涯中,我拜读过许多大神关于 Java 虚拟机的技术博客。在受益匪浅的同时,我发觉不少文章的门槛都比较高,而且过分注重实现细节,这并不是大多数的开发人员可以受益的调优方案。这么一来,许多原本对 Java 虚拟机感兴趣的同学, 也因为过高的门槛,以及短时间内看不到的收益,而放弃了对 Java 虚拟机的学习。
在收到极客时间的邀请后,我决定也挑战一下 Java 虚拟机的科普工作。和其他栏目一样,我会用简单通俗的语言,来介绍 Java 虚拟机的实现。具体到每篇文章,我将采用一个贯穿全文的案例来阐述知识点,并且给出相应的调优建议。在文章的末尾,我还将附上一个动手实践的环节,帮助你巩固对知识点的理解。
整个专栏将分为四大模块。
基本原理:剖析 Java 虚拟机的运行机制,逐一介绍 Java 虚拟机的设计决策以及工程实现;
高效实现:探索 Java 编译器,以及内嵌于 Java 虚拟机中的即时编译器,帮助你更好地理解 Java 语言特性,继而写出简洁高效的代码;
代码优化:介绍如何利用工具定位并解决代码中的问题,以及在已有工具不适用的情况下,如何打造专属轮子;
虚拟机黑科技:介绍甲骨文实验室近年来的前沿工作之一 GraalVM。包括如何在 JVM 上高效运行其他语言;如何混搭这些语言,实现 Polyglot;如何将这些语言事前编译(Ahead-Of-Time,AOT)成机器指令,单独运行甚至嵌入至数据库中运行。
我希望借由这四个模块 36 个案例,帮助你理解 Java 虚拟机的运行机制,掌握诊断手法和调优方式。最重要的,是激发你学习 Java 虚拟机乃至其他底层工作、前沿工作的热情。

知识框架图

(点击查看高清大图,iOS 用户可长按保存)
确认放弃笔记?
放弃后所记笔记将不保留。
新功能上线,你的历史笔记已初始化为私密笔记,是否一键批量公开?
批量公开的笔记不会为你同步至部落
公开
同步至部落
取消
完成
0/2000
荧光笔
直线
曲线
笔记
复制
AI
  • 深入了解
  • 翻译
    • 英语
    • 中文简体
    • 中文繁体
    • 法语
    • 德语
    • 日语
    • 韩语
    • 俄语
    • 西班牙语
    • 阿拉伯语
  • 解释
  • 总结

本文是一篇关于Java虚拟机(JVM)的技术文章,作者以自己的学术背景和工作经历为基础,介绍了学习Java虚拟机的重要性以及对程序性能优化的意义。作者指出,了解Java虚拟机的工作原理和内部机制,可以帮助程序员更好地优化应用程序的性能,同时为学习更深层次的Java技术打下基础。文章还介绍了学习Java虚拟机的好处,包括优化运行参数、规避Bug、了解垃圾回收算法和即时编译器实现等。作者还提到,Java虚拟机已经发展成为一套独立的高性能执行方案,不仅可以支持Java语言,还可以运行其他语言,如Scala、Clojure、Groovy和Kotlin。最后,作者介绍了自己的专栏内容和结构,将分为基本原理、高效实现、代码优化和虚拟机黑科技四大模块,帮助读者理解Java虚拟机的运行机制,掌握诊断手法和调优方式。整体而言,本文以通俗易懂的语言,为读者提供了学习Java虚拟机的动机和重要性,以及未来专栏的内容框架和目标。

2018-07-1693人觉得很赞给文章提建议

仅可试看部分内容,如需阅读全部内容,请付费购买文章所属专栏
《深入拆解 Java 虚拟机》
新⼈⾸单¥59
立即购买
登录 后留言

全部留言(129)

  • 最新
  • 精选
  • 置顶
    JVM 1:现在我的理解 1-1:三个英文单词的缩写,中文意思是Java虚拟机,作用是帮助执行Java字节码的,不同的平台有不同的JVM,这样java源代码经过编译为字节码之后就能在各种平台上运行了 1-2:JVM还有内存管理,垃圾回收等底层功能,这样程序员就不用太操心这些事情了 1-3:内存管理主要是将JVM的内存容量划分成不同的模块,使用不同的管理方式,核心目的是为了更少的内存使用更快的内存性能以及恰当的内存回收策略 1-4:垃圾回收之所以存在是因为JVM是运行在内存之中的,它的内存空间是有限的,当加载进内存的对象越来越多的时候,会影响JVM的运行性能,所以,要回收一些内存空间,垃圾回收的关键是识别出垃圾以及使用不影响JVM运行的回收策略 1-5:JVM是Java代码执行的地方,Java程序性能上出现了问题的时候,我们要从代码层面进行分析、定位、优化,但是我们怎么知道那段代码性能差哪?此时要看JVM中代码的执行情况,看看谁慢?为什么慢?这些我还不清楚咋快速定位,所以,我订阅了这个专栏 2我希望我能学到如下内容 2-1:Java源代码怎么变成Java字节码的? 2-2:Java字节码怎么进入JVM的? 2-3:Java 字节码进入JVM后是怎么放置的? 2-4:JVM执行字节码的时候怎么定位的?他怎么知道该执行那句代码了?它怎么知道那句代码是什么意思? 2-5:性能优化,我的理解是让干活快的干活,不让干的慢的干,如果做不到,就让干活快的多干,干的慢的少干?JVM的性能优化可能也类似,哪JVM怎么知道谁干的慢谁干的快?JVM在执行Java字节码的时候都是需要做什么事情呢?它怎么安排自己的工作的呢? 2-6:实际开发工作中怎么监控JVM的工作情况哪?怎么定位那些懒蛋哪?定位到了怎么解决他们哪?
    2018-07-21
    1
    236
  • 我的黄金时代
    置顶
    下面这个讲课的目录很给力
    2018-07-18
    1
  • Desperado
    置顶
    沙发期待中
    2018-07-18
    2
  • 木甘
    置顶
    是java10吗

    作者回复: 介绍的内容不局限于一个版本的。从8到11都会涉及到。

    2018-07-17
    18
  • lynd
    置顶
    能够对java虚拟机做分块的详细介绍不,最好能附上简短的代码介绍,谢谢!

    作者回复: 这个专栏会避免介绍具体的虚拟机代码。但我会在最后列举一些学习资料。

    2018-07-17
    7
  • 劳斯
    置顶
    JVM很有用,目测会是个不错的专栏,期待!
    2018-07-16
    41
  • 沙漏人生
    置顶
    已购,看看作者大能如何把复杂的东西简单化。
    2018-07-16
    10
  • zhenTomcat
    置顶
    期待
    2018-07-16
    3
  • 闪亮的老刘
    置顶
    希望不虚此行,希望有趣。
    2018-07-16
    2
  • 浮生老莫
    置顶
    期待老师后续的内容,刚想学JVM,就来了,再打磨打磨自己的技术
    2018-07-16
    8
收起评论
显示
设置
留言
99+
收藏
99+
沉浸
阅读
分享
手机端
快捷键
回顶部