新一代垃圾回收器ZGC设计与实现

0
(0)

新一代垃圾回收器ZGC设计与实现

出版社:机械工业出版社

出版年:2019-8-1

页数:212

定价:89元

装帧:平装

丛书:Java核心技术系列

ISBN:9787111633655

内容简介
······

Java 11版本包含一个全新的垃圾收集器ZGC,它由Oracle开发,承诺在数TB的堆上具有非常低的暂停时间。ZGC是2017年Oracle公司贡献给OpenJDK社区的,正式成为OpenJDK的开源项目。ZGC 所针对的是这些在未来普遍存在的大容量内存:TB 级别的堆容量,具有很低的停顿时间(小于 10 毫秒),对整体应用性能的影响也很小(对吞吐量的影响低于 15%)。ZGC 所采用的机制也可以在未来进行扩展,以支持一些令人兴奋的特性,如多层堆(用于热对象的 DRAM 和用于低频访问对象的 NVMe 闪存)

或压缩堆。

本书详细介绍ZGC涉及的基本概念和运行原理,以及调优方法。主要内容共9章,主要

内容有:垃圾回收器概述、ZGC内存管理、ZGC线程、ZGC垃圾回收算法的设计、ZGC日

志解读、ZGC参数和基准测试、ZGC的编译调试、ZGC特性总结和展望、ZGC的编译调试、Shenandoah简介等。

作者简介
······

彭成寒 高级Java工程师,目前主要从事风控系统设计、算法建模、大数据处理等工作,有超过10年的Java和C++开发经验。

目录
······

前言

第1章 垃圾回收器概述 1

1.1 垃圾回收算法 2

1.2 JVM垃圾回收器 2

1.2.1 串行回收 3

1.2.2 并行回收 4

1.2.3 CMS 4

1.2.4 G1 5

1.2.5 ZGC 15

1.2.6 Shenandoah 19

第2章 ZGC内存管理 21

2.1 操作系统地址管理 21

2.2 ZGC内存管理 22

2.2.1 多视图映射 25

2.2.2 ZGC多视图映射 27

2.2.3 页面设计 30

2.2.4 对NUMA的支持 31

2.2.5 ZGC中的物理内存管理 32

2.2.6 ZGC中的虚拟内存管理 34

2.2.7 ZGC内存预分配 35

2.3 ZGC对象分配管理 36

2.3.1 对象空间分配 39

2.3.2 页面分配 42

第3章 ZGC线程 48

3.1 线程的基本概念 48

3.2 控制线程 49

3.2.1 时钟触发器 51

3.2.2 消息触发 53

3.2.3 VMThread 56

3.3 工作线程 59

3.4 垃圾回收触发的时机 62

第4章 ZGC垃圾回收算法的设计 67

4.1 并发垃圾回收算法 67

4.1.1 并发垃圾回收算法概述 67

4.1.2 ZGC并发算法的设计 68

4.2 并发处理 70

4.2.1 并发处理概述 71

4.2.2 ZGC并发处理算法 73

4.2.3 ZGC并发处理算法演示 75

第5章 ZGC垃圾回收算法的实现 78

5.1 垃圾回收的实现 78

5.1.1 初始标记 78

5.1.2 并发标记 88

5.1.3 再标记和非强根并行标记 94

5.1.4 非强引用并发标记和引用并发处理 98

5.1.5 重置转移集 105

5.1.6 回收无效的页面 106

5.1.7 选择待回收的页面 106

5.1.8 初始化待转移集合的转移表 108

5.1.9 初始转移 108

5.1.10 并发转移 110

5.1.11 垃圾回收算法再讨论 111

5.2 垃圾回收算法演示 112

第6章 ZGC日志解读 120

6.1 Xlog简介 120

6.2 测试用例设计 123

6.3 ZGC初始化信息 125

6.4 垃圾回收触发信息 127

6.5 垃圾回收过程中每一步的信息 130

6.6 统计信息 137

6.6.1 垃圾回收器信息 137

6.6.2 竞争信息 137

6.6.3 同步等待信息 139

6.6.4 内存信息 140

6.6.5 垃圾回收步骤信息 142

6.6.6 子阶段信息 144

6.6.7 线程信息 146

第7章 ZGC参数和基准测试 147

7.1 参数简介 147

7.1.1 ZGC新引入参数 147

7.1.2 GC通用参数 149

7.2 测试评估 150

7.2.1 测试准备 151

7.2.2 测试与测试报告 154

第8章 ZGC的发展与展望 160

8.1 类回收 161

8.2 单代回收 164

8.3 新功能和多平台 165

第9章 JVM编译调试 166

9.1 下载源代码 166

9.2 代码概览 167

9.3 编译JVM 168

9.4 调试ZGC 169

9.4.1 启动GDB 170

9.4.2 对象分配 170

9.4.3 触发垃圾回收 172

9.4.4 初始标记 172

9.4.5 并发标记 173

9.4.6 初始转移 174

9.4.7 并发转移 176

9.4.8 重定位 176

9.5 使用HSDB学习JVM中对象布局 178

9.5.1 C++对象布局原理 178

9.5.2 Java对象布局原理 180

9.5.3 用HSDB分析Java对象布局 180

第10章 Shenandoah简介 192

10.1 概述 192

10.2 Shenandoah垃圾回收策略 193

10.3 Shenandoah垃圾回收算法 194

10.3.1 正常回收算法 195

10.3.2 遍历回收算法 197

附录A Cassandra简介 200

附录B YCSB简介 202

评论 ······

思路非常清晰。第一章简单介绍G1回收器足见作者功力。目前国内第一本介绍ZGC的书。支持。

今年阅读的最佳技术书籍。用最简洁的描述讲解了zgc最核心的设计。这种书太难得了!作者十分棒,超过5星,盛赞这本书!

推荐可以看看ZGC 不过由于zgc Jdk15还在不断优化中 有些可能有变化

还没有阅读过.有看过的同学帮评下吗.

点击星号评分!

平均分 0 / 5. 投票数: 0

还没有投票!请为他投一票。

推荐阅读

评论 抢沙发

评论前必须登录!

 

登录

找回密码

注册