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

新一代垃圾回收器ZGC设计与实现 pdf epub mobi txt 电子书 下载 2025

出版者:机械工业出版社
作者:
出品人:
页数:212
译者:
出版时间:2019-8-1
价格:89元
装帧:平装
isbn号码:9787111633655
丛书系列:Java核心技术系列
图书标签:
  • JVM
  • Java
  • 计算机
  • 计算机科学
  • 虚拟机
  • 好书,值得一读
  • pl
  • ZGC
  • 垃圾回收
  • 设计
  • 实现
  • Java
  • 内存管理
  • 高性能
  • 并发
  • 系统编程
  • 自动化
想要找书就要到 图书目录大全
立刻按 ctrl+D收藏本页
你会得到大惊喜!!

具体描述

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
· · · · · · (收起)

读后感

评分

评分

评分

评分

评分

用户评价

评分

之前上学的时候有一个梗,说在食堂里吃饭,吃完把餐盘端走清理的是 C++ 程序员,吃完直接就走的是 Java 程序员。确实,在 Java 的世界里,似乎我们不用对垃圾回收那么的关注。很多初学者不懂 GC,也能写出一个能用甚至还不错的程序或系统。但其实这并不代表 Java 的 GC 就不重要。相反,它是那么的重要和复杂,以至于出了问题,那些初学者除了打开 GC 日志,看着一堆0101的天文,啥也做不了。

评分

之前上学的时候有一个梗,说在食堂里吃饭,吃完把餐盘端走清理的是 C++ 程序员,吃完直接就走的是 Java 程序员。确实,在 Java 的世界里,似乎我们不用对垃圾回收那么的关注。很多初学者不懂 GC,也能写出一个能用甚至还不错的程序或系统。但其实这并不代表 Java 的 GC 就不重要。相反,它是那么的重要和复杂,以至于出了问题,那些初学者除了打开 GC 日志,看着一堆0101的天文,啥也做不了。

评分

之前上学的时候有一个梗,说在食堂里吃饭,吃完把餐盘端走清理的是 C++ 程序员,吃完直接就走的是 Java 程序员。确实,在 Java 的世界里,似乎我们不用对垃圾回收那么的关注。很多初学者不懂 GC,也能写出一个能用甚至还不错的程序或系统。但其实这并不代表 Java 的 GC 就不重要。相反,它是那么的重要和复杂,以至于出了问题,那些初学者除了打开 GC 日志,看着一堆0101的天文,啥也做不了。

评分

之前上学的时候有一个梗,说在食堂里吃饭,吃完把餐盘端走清理的是 C++ 程序员,吃完直接就走的是 Java 程序员。确实,在 Java 的世界里,似乎我们不用对垃圾回收那么的关注。很多初学者不懂 GC,也能写出一个能用甚至还不错的程序或系统。但其实这并不代表 Java 的 GC 就不重要。相反,它是那么的重要和复杂,以至于出了问题,那些初学者除了打开 GC 日志,看着一堆0101的天文,啥也做不了。

评分

之前上学的时候有一个梗,说在食堂里吃饭,吃完把餐盘端走清理的是 C++ 程序员,吃完直接就走的是 Java 程序员。确实,在 Java 的世界里,似乎我们不用对垃圾回收那么的关注。很多初学者不懂 GC,也能写出一个能用甚至还不错的程序或系统。但其实这并不代表 Java 的 GC 就不重要。相反,它是那么的重要和复杂,以至于出了问题,那些初学者除了打开 GC 日志,看着一堆0101的天文,啥也做不了。

本站所有内容均为互联网搜索引擎提供的公开搜索信息,本站不存储任何数据与内容,任何内容与数据均与本站无关,如有需要请联系相关搜索引擎包括但不限于百度google,bing,sogou

© 2025 book.wenda123.org All Rights Reserved. 图书目录大全 版权所有