封面
版权信息
作者简介
前言
第一部分 Java虚拟机和垃圾回收基础知识
第1章 Java代码执行过程介绍
1.1 代码执行过程概述
1.1.1 编译执行
1.1.2 解释执行
1.1.3 混合执行
1.2 从C代码执行过程看编译器和操作系统协同工作
1.2.1 从源代码到目标代码
1.2.2 操作系统如何执行目标代码
1.3 从C++代码的执行过程看编译器支持面向对象语言
1.3.1 封装支持
1.3.2 继承支持
1.3.3 多态支持
1.4 Java代码执行过程简介
1.4.1 Java代码到字节码
1.4.2 JVM加载字节码
1.4.3 解释执行
1.4.4 编译执行
1.5 内存管理
1.6 线程管理
1.7 扩展阅读:JIT概述
第2章 JVM中垃圾回收相关的基本知识
2.1 GC算法分类
2.2 GC涉及的对象表示
2.3 GC算法概述
2.3.1 复制算法
2.3.2 标记清除算法
2.3.3 标记压缩算法
2.3.4 分代回收
2.4 GC的根
2.4.1 强根
2.4.2 Java引用引入的弱根
2.4.3 JVM优化实现引入的弱根
2.4.4 JVM中根的构成
2.5 安全点
2.5.1 解释线程进入安全点
2.5.2 编译线程进入安全点
2.5.3 本地线程进入安全点
2.5.4 JVM内部并发线程进入安全点
2.5.5 安全点小结
2.6 扩展阅读:垃圾回收器请求内存设计
第二部分 JVM垃圾回收器详解
第3章 串行回收
3.1 分代堆内存管理概述
3.1.1 堆设计
3.1.2 分代边界
3.1.3 回收设计思路
3.2 新生代内存管理
3.2.1 新生代内存分配
3.2.2 垃圾回收的触发机制
3.2.3 适用于单线程的复制回收算法
3.2.4 适用于分代的复制回收算法
3.2.5 引用集管理
3.3 老生代内存管理
3.3.1 堆空间回收的触发
3.3.2 堆空间回收算法过程介绍
3.3.3 适用于分代的标记压缩算法
3.3.4 标记-压缩的优化
3.4 扩展阅读:不同的复制算法比较及对程序员的启迪
第4章 并发标记清除回收
4.1 内存管理
4.2 并行的新生代回收
4.2.1 一般根集合的并行处理
4.2.2 老生代到新生代引用的并行处理
4.2.3 卡表的竞争操作介绍
4.2.4 并行复制算法卡表设计
4.3 并发回收的难点
4.3.1 三色标记法
4.3.2 难点示意图
4.3.3 读屏障处理
4.3.4 写屏障之增量标记
4.3.5 写屏障之SATB标记
4.4 并发的老生代回收
4.4.1 内存管理
4.4.2 标记清除算法概述
4.4.3 并发算法触发时机
4.4.4 并发标记清除之初始标记
4.4.5 并发标记清除之并发标记
4.4.6 并发标记清除之预清理
4.4.7 并发标记清除之可终止预清理
4.4.8 并发标记清除之再标记
4.4.9 并发标记清除之清除
4.4.10 并发标记清除之内存空间调整
4.4.11 并发标记清除之复位
4.4.12 并发算法难点
4.5 Full GC
4.6 扩展阅读:标记栈溢出的各种处理方法
4.6.1 重新标记法
4.6.2 全局列表法
4.6.3 逆指针法
4.7 扩展阅读:元数据内存管理
4.7.1 内存管理
4.7.2 分配
4.7.3 回收
4.7.4 元数据管理的优化
第5章 并行回收
5.1 内存管理
5.1.1 内存管理模型
5.1.2 NUMA支持
5.1.3 内存分配和GC触发流程
5.2 Minor GC
5.3 Full GC
5.3.1 算法概述
5.3.2 算法实现与演示
5.4 扩展阅读:并行任务的负载均衡机制
5.4.1 并行任务的窃取
5.4.2 并行任务的终止
第6章 垃圾优先
6.1 内存管理概述
6.1.1 分代下的分区管理
6.1.2 新生代大小设计
6.1.3 回收机制的设计
6.2 引用集设计
6.2.1 引用集存储
6.2.2 引用集处理流程
6.2.3 引用集写入
6.3 新生代回收和混合回收
6.3.1 回收过程中引用关系处理
6.3.2 混合回收导致停顿时间不符合预期的处理方法
6.3.3 NUMA-Aware支持
6.3.4 云场景的支持
6.3.5 并发标记和Minor GC、Mixed GC的交互
6.4 并发标记
6.4.1 SATB算法介绍
6.4.2 增量并发标记算法
6.5 Full GC
6.5.1 串行实现算法
6.5.2 并行实现算法
6.6 扩展阅读:OpenJ9中的Balanced GC介绍
6.6.1 内存管理的区别
6.6.2 大对象设计的区别
6.6.3 回收的区别
6.6.4 并发标记的区别
6.6.5 Full GC与Balanced GC的区别
第7章 Shenandoah
7.1 内存模型
7.1.1 内存分配
7.1.2 垃圾回收的触发
7.2 并发标记设计
7.3 并发转移设计
7.3.1 引用不变性
7.3.2 目标空间不变性
7.3.3 源空间不变性
7.4 垃圾回收实现
7.4.1 垃圾回收策略
7.4.2 垃圾回收模式
7.4.3 正常回收算法
7.4.4 优化模式垃圾回收
7.4.5 垃圾回收的降级
7.4.6 遍历回收算法
7.4.7 垃圾回收触发的时机
7.4.8 其他细节
7.5 扩展阅读:OpenJ9中的实时垃圾回收器Metronome介绍
第8章 ZGC
8.1 内存管理
8.1.1 内存管理模型
8.1.2 高速分配设计
8.2 回收设计
8.2.1 算法概述
8.2.2 视图状态
8.2.3 读屏障
8.2.4 高效的标记和转移设计
8.2.5 垃圾回收触发的时机
8.3 垃圾回收实现
8.3.1 回收实现
8.3.2 多线程高效地标记
8.3.3 多线程高效地转移
8.3.4 标记和重定位合并的优缺点
8.4 ZGC新特性概览
8.4.1 并发类卸载
8.4.2 并发根扫描
8.5 扩展阅读:分配预测模型的理论基础
第三部分 JVM中垃圾回收相关参数介绍
第9章 GC通用参数
9.1 GC生产参数
9.1.1 GC选择相关参数
9.1.2 GC工作线程相关参数
9.1.3 内存设置相关参数
9.1.4 停顿时间相关参数
9.1.5 执行效率相关参数
9.1.6 大页和NUMA参数
9.1.7 GC日志相关参数
9.1.8 其他参数
9.2 GC实验参数
9.2.1 GC选择相关参数
9.2.2 引用处理相关参数
9.2.3 GC任务均衡相关参数
9.3 GC诊断参数
9.3.1 GC工作线程相关参数
9.3.2 GC校验相关参数
9.3.3 其他参数
9.4 可动态调整的参数
9.5 重要参数小结
第10章 Parallel GC参数
10.1 生产参数
10.1.1 并行压缩相关参数
10.1.2 并行复制相关参数
10.2 重要参数小结
第11章 CMS参数
11.1 生产参数
11.1.1 老生代分配相关参数
11.1.2 老生代合并相关参数
11.1.3 空闲列表管理相关参数
11.1.4 老生代预清理相关参数
11.1.5 老生代再标记相关参数
11.1.6 Minor GC相关参数
11.1.7 老生代GC触发控制相关参数
11.1.8 老生代并行/并发控制相关参数
11.1.9 其他参数
11.2 诊断参数
11.2.1 老生代碎片化相关参数
11.2.2 Minor GC效率相关参数
11.2.3 其他参数
11.3 可动态调整的参数
11.4 重要参数小结
第12章 G1参数
12.1 生产参数
12.1.1 并发标记相关参数
12.1.2 引用集处理相关参数
12.1.3 内存设置相关参数
12.1.4 Minor GC相关参数
12.1.5 GC触发控制相关参数
12.1.6 混合回收相关参数
12.2 实验参数
12.2.1 内存设置相关参数
12.2.2 Minor GC相关参数
12.2.3 混合回收相关参数
12.2.4 其他参数
12.3 可动态调整的参数
12.4 诊断参数
12.5 重要参数小结
第13章 Shenandoah参数
13.1 生产参数
13.1.1 垃圾回收模式相关参数
13.1.2 垃圾回收策略相关参数
13.2 实验参数
13.2.1 内存设置相关参数
13.2.2 垃圾回收策略及相关参数
13.2.3 并发标记相关参数
13.3 诊断参数
13.4 重要参数小结
第14章 ZGC参数
14.1 生产参数
14.2 诊断参数
14.3 重要参数小结
第四部分 ARM服务器上的GC挑战和优化
第15章 泰山服务器概述
15.1 ARM架构
15.1.1 ARM介绍
15.1.2 ARMv8-A特性
15.2 鲲鹏处理器
15.2.1 芯片架构
15.2.2 内存管理子系统
15.2.3 流水线技术
15.2.4 内存一致性
15.3 泰山服务器
第16章 AArch64平台上的GC挑战和优化
16.1 内存序
16.2 众核架构对性能的影响
16.3 NUMA对性能的影响
16.4 其他影响
更新时间:2022-08-29 15:14:01