搜索
高级检索
高级搜索
书       名 :
著       者 :
出  版  社 :
I  S  B  N:
文献来源:
出版时间 :
深入解析Java虚拟机HotSpot
0.00     定价 ¥ 79.00
图书来源: 浙江图书馆(由JD配书)
此书还可采购14本,持证读者免费借回家
  • 配送范围:
    浙江省内
  • ISBN:
    9787111670315
  • 作      者:
    杨易
  • 出 版 社 :
    机械工业出版社
  • 出版日期:
    2020-12-01
收藏
编辑推荐

(1)作者是阿里云Java技术专家,热衷于研究编程语言的设计与实现,对Java虚拟机和编译器都有较深入的研究。
(2)深入分析HotSpot VM的核心源码,全面解析运行时、垃圾回收器、即时编译器的实现原理和工作机制
(3)详细描述虚拟机底层实现,同时与上层Java应用和库相结合,为JVM的开发、调优和排错指明方向

展开
作者简介

杨易

Java开发工程师,就职于阿里云基础设施部。.热衷于研究编程语言的设计与实现,对Java语言的设计与实现有非常深入的研究,尤其是Java的虚拟机HotSpot VM,在JVM的开发、调优和排错方面积累了丰富的经验。此外,在编译器领域也有较深厚的积累。.有着自由软件精神的开发者,是GitHub中国区followers数量排名前100的开源项目维护者。

展开
内容介绍

很多JVM的底层技术细节你是否只了解表面?
面对JVM Crash或性能调优方面的问题时你是否会束手无策?
面对上层Java应用发生的偏离预期的行为是否会不知所措?
……
这本书以源码分析为基础,从运行时、垃圾回收器、即时编译器3个维度全面、深入解析HotSpot VM的底层实现和工作机制,同时与上层的Java语言和库结合,指导读者解决JVM开发、JVM调优和JVM排错方面遇到的各种问题。 


广度与深度兼顾:广度上涵盖Graal VM、CDS、Instrumentation、编译重放、非标准字节码、RTM锁、JIT调试工具、EpsilonGC/ShenandoahGC/ZGC、G1字符串去重等重要知识点;深度上深入解析了C1、C2、G1GC、ObjectMonitor、Mutex、模板解释器等的底层实现。

全书共 11 章,参考 OpenJDK 社区的划分方式来组织内容,分为运行时、即时编译器、垃圾回收器三个部分。

第壹部分(第1~6章) 运行时
首先,从Java生态系统的角度,简单介绍了JDK、JVM、JEP、HotSpot VM、Graal VM,引导读者快速进入Java虚拟机的世界;然后从源码的角度深入解析了HotSpot VM的类可用机制、对象和类、运行时、模板解释器和并发设施。

第二部分(第7~9章) 即时编译器
首先重点介绍了即时编译器技术、编译理论、编译器调试方法等编译器的基础知识;然后详细讲解了C1和C2两个即时编译器的实现原理、工作机制和优化方法。

第三部分(第10~11章) 垃圾回收器
首先全面介绍了Epsilon GC、Serial GC、Parallel GC、CMS GC、G1 GC、Shenandoah GC、ZGC等各种垃圾回收器,然后重点剖析了G1 GC。

展开
精彩书评

本书内容翔实,结合实际工作中的具体问题,对JVM进行了深入、全方位的剖析,如栈上替换、模板解释器、即时编译器、AppCDS、RTM锁、编译重放,等等。无论是上层架构,还是底层设计,都娓娓道来, 无论是Java开发者还是C++开发者,都值得认真一读,强烈推荐。

—— 赵海平  前Facebook首席工程师,前阿里巴巴高级研究员



想要编写出优秀的软件,就势必要对已有的、底层的软件栈有清晰的了解,这样才能在遇到麻烦时直指问题核心,在设计新方案时总览全局。很高兴看到本书的出版,它不仅讲解了运行时、即时编译器、垃圾回收器的原理,还从当今应用最广泛的Java语言实现——HotSpot VM出发,配合代码示例、算法图解、调试技巧,帮助读者跨越学习中理论和实践的鸿沟。如果你在平时的工作学习中需要大量使用Java,想要提升软件开发和调试的效率,又恰好对每天使用的工具的内部黑魔法感兴趣,那么这本书将给你惊喜。

—— 彭飞  NVIDIA高级编译器工程师



大多数程序员都有中年危机,而深入研究技术,将技术做深、做精、做专是技术人员避免中年危机的明智之举。对于Java程序员来说,这本书能带你走向Java底层,深入了解HotSpot虚拟机的运行原理与实现机制,是走向Java技术巅峰的优选。

—— 马智  《深入解析Java编译器:源码剖析与实例详解》作者 

 


展开
目录

第1章 Java大观园  1

1.1 OpenJDK  1

1.2 JEP  2

1.3 Java虚拟机  4

1.4 HotSpot VM  5

1.4.1 源码模块  7

1.4.2 构建和调试  7

1.4.3 回归测试  12

1.5 Graal VM  14

1.6 本章小结  16

第2章 类可用机制  17

2.1 类的加载  17

2.1.1 字节码  17

2.1.2 类加载器  19

2.1.3 文件解析  21

2.2 类的链接  23

2.2.1 字节码验证  24

2.2.2 字节码重写  24

2.2.3 方法链接  26

2.3 类的初始化  32

2.4 类的重定义  35

2.5 本章小结  36

第3章 对象和类  38

3.1 对象与类  38

3.2 对象  39

3.2.1 创建对象  39

3.2.2 对象头  41

3.2.3 对象哈希值  43

3.3 类  44

3.3.1 字段遍历  45

3.3.2 虚表  46

3.4 本章小结  48

第4章 运行时  49

4.1 线程创生纪  49

4.1.1 容器化支持  51

4.1.2 Java线程  52

4.1.3 虚拟机线程  54

4.1.4 编译器线程  57

4.1.5 服务线程  58

4.1.6 计时器线程  58

4.2 Java线程  58

4.2.1 线程启动  60

4.2.2 线程停止  61

4.2.3 睡眠与中断  63

4.3 栈帧  66

4.4 Java/JVM沟通  68

4.4.1 JNI  69

4.4.2 JavaCalls  72

4.5 Unsafe类  74

4.5.1 堆外内存  75

4.5.2 内存屏障  75

4.5.3 阻塞和唤醒  76

4.5.4 对象数据修改  76

4.6 本章小结  77

第5章 模板解释器  78

5.1 解释器体系  78

5.1.1 C++解释器行为  78

5.1.2 模板解释器行为  79

5.2 机器代码片段  81

5.3 CodeCache  82

5.4 指令缓存刷新  84

5.5 解释器生成  86

5.5.1 普通方法入口  86

5.5.2 方法加锁  89

5.5.3 本地方法入口  90

5.5.4 标准字节码  91

5.5.5 非标准字节码  106

5.6 本章小结  107

第6章 并发设施  108

6.1 指令重排序  108

6.1.1 编译器重排序  109

6.1.2 处理器重排序  110

6.2 内存模型  112

6.2.1 happens-before内存模型  113

6.2.2 Java内存模型  114

6.3 基础设施  116

6.3.1 原子操作  116

6.3.2 ParkEvent  116

6.3.3 Parker  118

6.3.4 Monitor  120

6.4 锁优化  126

6.4.1 偏向锁  127

6.4.2 基本对象锁  128

6.4.3 重量级锁  128

6.4.4 RTM锁  131

6.5 本章小结  132

第7章 编译概述  133

7.1 编译器简介  133

7.1.1 运行时代码生成  134

7.1.2 JIT编译器  135

7.1.3 AOT编译器  136

7.1.4 JVMCI JIT编译器  136

7.2 即时编译技术  137

7.2.1 分层编译  137

7.2.2 栈上替换  138

7.2.3 退优化  139

7.3 编译理论基础  139

7.3.1 中间表示  139

7.3.2 基本块与控制流图  140

7.3.3 静态单赋值  142

7.3.4 规范化  142

7.3.5 值编号  143

7.3.6 自顶向下重写系统  144

7.3.7 循环不变代码外提概述  144

7.4 调试方法  145

7.4.1 编译日志  145

7.4.2 编译神谕  146

7.4.3 可视化工具  146

7.5 本章小结  149

第8章 C1编译器  150

8.1 编译流程  150

8.1.1 进入C1  150

8.1.2 高级中间表示  152

8.1.3 低级中间表示  153

8.2 从字节码到HIR  155

8.2.1 识别基本块  155

8.2.2 抽象解释  156

8.3 HIR代码优化  158

8.3.1 规范化  158

8.3.2 内联  159

8.3.3 基本块优化  160

8.3.4 值编号  160

8.3.5 数组范围检查  162

8.3.6 循环不变代码外提  162

8.4 从HIR到LIR  164

8.4.1 return生成  165

8.4.2 new生成  165

8.4.3 goto生成  166

8.4.4 线性扫描寄存器分配  167

8.5 本章小结  171

第9章 C2编译器  172

9.1 编译流程  172

9.1.1 进入C2  172

9.1.2 理想图  174

9.1.3 理想图流程概述  180

9.1.4 C2代码优化  183

9.1.5 代码生成流程  185

9.1.6 设置机器代码  186

9.2 构造理想图  187

9.2.1 构造示例  187

9.2.2 Identity、Ideal、GVN  191

9.3 机器无关优化  193

9.3.1 IGVN  193

9.3.2 逃逸分析  194

9.3.3 向量化  197

9.4 代码生成  199

9.4.1 指令选择  199

9.4.2 图着色寄存器分配  200

9.5 本章小结  203

第10章 垃圾回收  204

10.1 垃圾回收基础概述  204

10.1.1 GC Root  205

10.1.2 安全点  206

10.1.3 线程局部握手  208

10.1.4 GC屏障  209

10.2 Epsilon GC  209

10.2.1 源码结构  209

10.2.2 EpsilonHeap  210

10.2.3 对象分配  211

10.2.4 回收垃圾  212

10.3 Serial GC  212

10.3.1 弱分代假说  212

10.3.2 卡表  213

10.3.3 Young GC  214

10.3.4 Full GC  218

10.3.5 世界停顿  221

10.4 Parallel GC  221

10.4.1 多线程垃圾回收  221

10.4.2 GC任务管理器  223

10.4.3 并行与并发  226

10.5 CMS GC  227

10.5.1 回收策略  227

10.5.2 对象丢失问题  228

10.5.3 Old GC周期  229

10.5.4 并发模式失败  234

10.5.5 堆碎片化  235

10.6 G1 GC  235

10.6.1 简介  235

10.6.2 混合回收  236

10.7 Shenandoah GC  237

10.8 ZGC  239

10.9 本章小结  241

第11章 G1 GC  242

11.1 G1 GC简介  242

11.1.1 基于Region的堆  242

11.1.2 记忆集RSet  243

11.1.3 停顿预测模型  244

11.2 Young GC  245

11.2.1 选择CSet  245

11.2.2 清理根集  246

11.2.3 处理RSet  247

11.2.4 对象复制  247

11.3 Mixed GC  248

11.3.1 SATB  249

11.3.2 全局并发标记  251

11.3.3 对象复制  254

11.4 Full GC  254

11.5 字符串去重  255

11.6 本章小结  257


展开
加入书架成功!
收藏图书成功!
我知道了(3)
发表书评
读者登录

请选择您读者所在的图书馆

选择图书馆
浙江图书馆
点击获取验证码
登录
没有读者证?在线办证