Skip to content

《深入理解Java虚拟机(第3版)》样例代码&勘误

Notifications You must be signed in to change notification settings

AlexanderZhou01/jvm_book

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 

Repository files navigation

《深入理解Java虚拟机(第3版)》

  本工程为《深入理解Java虚拟机(第3版)》书中的样例代码,以方便读者自行测试。部分代码需要在特定的虚拟机版本、参数下运行,在代码前均已“VM Args”的注释进行标注。

  书中的勘误也会在本文中持续更新,读者可通过issues提交新的勘误,如对新版有任何建议,也欢迎以issues或任何其他您方便的形式提出。

勘误列表:

  • Page 30:JDK 7则【还完全】处于研发状态的半成品。
    更正:JDK 7则【完全是】处于研发状态的半成品。

  • Page 38:由于JDK12已EOL,RedHat的GitHub上目前只维护8、11两个LTS和13这个正在半年支持期内的JDK版本,JDK12的Repo已经关闭(但从Git的History中挖掘出来是很容易的),为了便于读者获取 CMakeLists.txt,我上传了一份到本仓库中。此文件版权归原作者所有。(编辑在更新勘误时可跳过此条)

  • Page 80:HotSpot虚拟机里面关注吞吐量的Parallel 【Scavenge】收集器是基于标记-整理算法的。
    更正:HotSpot虚拟机里面关注吞吐量的Parallel 【Old】收集器是基于标记-整理算法的。

  • Page 106:在回收时通过这张表格就可以得出哪些Region之间产生了【跨代引用】。
    更正:在回收时通过这张表格就可以得出哪些Region之间产生了【跨Region的引用】。

  • Page 106:降低了处理跨代指针时的记忆集维护消耗,也降低了伪共享问题(【见3.4.4节】)的发生概率。
    更正:降低了处理跨代指针时的记忆集维护消耗,也降低了伪共享问题(【见3.4.5节】)的发生概率。

  • Page 134:如果在Survivor空间中【相同年龄】所有对象大小的总和大于Survivor空间的一半
    更正:如果在Survivor空间中【低或等于某个年龄的】所有对象大小的总和大于Survivor空间的一半

  • Page 134:满足【同年】对象达到Survivor空间的一半规则
    更正:满足【低于或等于某年龄的】对象达到Survivor空间的一半规则

  • Page 160-161:代码中类名“SynAddRunalbe”中英文“Runalbe”为拼写错误,应为“SynAddRunnable”,代码中一共有4处,图片中有1处。

  • Page 265:创建动作由字节码指令【newarray】触发
    更正:创建动作由字节码指令【anewarray】触发

  • Page 274:被访问类C是public的,不与访问类D处于同一个模块,但是被访问类C的模块允许【被访问类D】的模块进行访问。
    更正:被访问类C是public的,不与访问类D处于同一个模块,但是被访问类C的模块允许【访问类D】的模块进行访问。

  • Page 461:图12-6,New->Running,Running->Terminated这两个是单向箭头,交给编辑的原稿上也还是单向的,应该是排版修图时搞错变成双向了,请编辑同学修正过来。

  • Page 462:【以前处理一个请求可以允许花费很长时间在单体应用中】,具有这种线程切换成本也是无伤大雅的
    语句不通,更正为:【在以前的单体应用中,处理一个请求可以允许花费很长时间】,具有这种线程切换成本也是无伤大雅的

  • Page 462:现实的需求在迫使Java去研究新的解决方案,【同】大家又怀念起以前绿色线程的种种好处
    更正为:现实的需求在迫使Java去研究新的解决方案,【此时】大家又怀念起以前绿色线程的种种好处

以下勘误内容已在第3次重印版(2020-2-20日)修正


  • Page 27:到了JDK 10,HotSpot又重构了Java虚拟机的垃圾收集器接口 (Java Virtual Machine 【Compiler】 Interface)
    更正:到了JDK 10,HotSpot又重构了Java虚拟机的垃圾收集器接口 (Java Virtual Machine 【Garbage】 Interface)

  • Page 37:譬如【Eclipst】 CDT或者NetBeans来进行的话
    更正:譬如【Eclipse】 CDT或者NetBeans来进行的话

  • Page 110:对象的读取、写入、对象的比较、【为对象哈希值计算】、用对象加锁等等
    更正:对象的读取、写入、对象的比较、【为对象计算哈希值】、用对象加锁等等

  • Page 113:图3-19中,【Larage】为笔误,应为【Large】

  • Page 238:13: iload_1 后的注释应该是字节码第14行的,即

    13: iload_1 // 保存x到returnValue中,此时x=2
    14: istore 4

    改为:

    13: iload_1
    14: istore 4 // 保存x到returnValue中,此时x=2

  • Page 254:算术指令用于对【两个操作数栈上的值】进行某种特定运算
    对语序修改以避免歧义:算术指令用于对【操作数栈上的两个值】进行某种特定运算

  • Page 259:13 astore_3 后注释【Taget】为笔误,应为【Target】

  • Page 265/266:在266页正文中出现两次注释一,其中第一个注释是265页才对,应该是排版问题,请编辑再版时注意。

  • Page 278:代码清单7-5,第一行注释:给变量【复制】可以正常编译通过
    更正: 给变量【赋值】可以正常编译通过

  • Page 278:代码清单7-5,第二行注释:这句编译器会提示“非法【向前】引用”
    更正: 这句编译器会提示“非法【前向】引用”

  • Page 290:用在IntelliJ 【IDE】、Eclipse这些IDE上做HotSwap……
    更正: 用在IntelliJ 【IDEA】、Eclipse这些IDE上做HotSwap……

  • Page 312:代码实例中出现三处【gay】,譬如Father gay = new Son(); 均应为【guy】,这个不影响代码运行,只是不太雅观。

  • Page 317:产生这种差别产生的根本原因是Java语言在编译期间【却】已将println(String)方法完整的符号引用。
    更正:产生这种差别产生的根本原因是Java语言在编译期间【就】已将println(String)方法完整的符号引用。

  • Page 322:由于注解中John Rose博客文章中的代码托管网站Kenai.com已经关闭,为了便于读者获取INDY工具,我上传了一份到本仓库中(源码,在src/indify目录)。此文件版权归原作者John Rose所有。(编辑在更新勘误时可跳过此条)

  • Page 348:通常解决【类】问题有以下几种途径
    更正:通常解决【此类】问题有以下几种途径

  • Page 372:譬如将【代码清单10-2】稍微修改一下,变成下面代码清单10-7这个样子
    更正:譬如将【代码清单10-4】稍微修改一下,变成下面代码清单10-7这个样子

  • Page 396:【图11-2】和【图11-3】都仅仅是描述了客户端模式虚拟机的即时编译方式
    更正:【图11-3】和【图11-4】都仅仅是描述了客户端模式虚拟机的即时编译方式

以下勘误内容已在第2次重印版(2019-12-27日)修正


  • 前言部分:读者反馈信箱:[email protected]
    更正:由于这个信箱由于一直只收未发,刚印刷后收到Google的通知此账号已自动作废。而且根据Google规定,作废后无法注册同名邮箱。下次重印将修改为本工程地址:https://github.com/fenixsoft/jvm_book。

  • Page 9:支持HTTP 2客户【单】API等91个JEP
    更正:支持HTTP 2客户【端】API等91个JEP

  • Page 64:在【代码清单2-8】里笔者借助了CGLib……
    更正:在【代码清单2-9】里笔者借助了CGLib……

  • Page 368: 【ArrayList<int>】与ArrayList<String>其实是同一个类型
    更正:【ArrayList<Integer>】与ArrayList<String>其实是同一个类型

About

《深入理解Java虚拟机(第3版)》样例代码&勘误

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 92.5%
  • CMake 7.5%