深入理解Java虚拟机:JVM高级特性与最佳实践

第2版

8.9702 评价豆瓣读书
阅读
¥25.00
  • 导言
  • 目录
  • 作品信息

《深入理解Java虚拟机:JVM高级特性与最佳实践》第1版两年内印刷近10次,4家网上书店的评论近4?000条,98%以上的评论全部为5星级的好评,是整个Java图书领域公认的经典著作和超级畅销书,繁体版在台湾也十分受欢迎。第2版在第1版的基础上做了很大的改进:根据最新的JDK 1.7对全书内容进行了全面的升级和补充;增加了大量处理各种常见JVM问题的技巧和最佳实践;增加了若干与生产环境相结合的实战案例;对第1版中的错误和不足之处的修正;等等。第2版不仅技术更新、内容更丰富,而且实战性更强。

《深入理解Java虚拟机:JVM高级特性与最佳实践》共分为五大部分,围绕内存管理、执行子系统、程序编译与优化、高效并发等核心主题对JVM进行了全面而深入的分析,深刻揭示了JVM的工作原理。第一部分从宏观的角度介绍了整个Java技术体系、Java和JVM的发展历程、模块化,以及JDK的编译,这对理解本书后面内容有重要帮助。第二部分讲解了JVM的自动内存管理,包括虚拟机内存区域的划分原理以及各种内存溢出异常产生的原因;常见的垃圾收集算法以及垃圾收集器的特点和工作原理;常见虚拟机监控与故障处理工具的原理和使用方法。第三部分分析了虚拟机的执行子系统,包括类文件结构、虚拟机类加载机制、虚拟机字节码执行引擎。第四部分讲解了程序的编译与代码的优化,阐述了泛型、自动装箱拆箱、条件编译等语法糖的原理;讲解了虚拟机的热点探测方法、HotSpot的即时编译器、编译触发条件,以及如何从虚拟机外部观察和分析JIT编译的数据和结果;第五部分探讨了Java实现高效并发的原理,包括JVM内存模型的结构和操作;原子性、可见性和有序性在Java内存模型中的体现;先行发生原则的规则和使用;线程在Java语言中的实现原理;虚拟机实现高效并发所做的一系列锁优化措施。

周志明:资深Java技术专家,对JavaEE企业级应用开发、OSGi、Java虚拟机和工作流等都有深入的研究,并在大量的实践中积累了丰富的经验。尤其精通Java虚拟机,撰写了大量与JVM相关的经典文章,被各大技术社区争相转载,是ITeye等技术社区公认的Java虚拟机方面的领袖人物之一。除本书外,还著有经典著作《深入理解OSGi:Equinox原理、应用与最佳实践》,广获读者好评。现任远光软件股份有限公司开发部总经理兼架构师,先后参与过国家电网、南方电网等多个国家级大型ERP项目的平台架构工作,对软件系统架构也有深刻的认识和体会。

  1. 前言
  2. 第2版与第1版的区别
  3. 本书面向的读者
  4. 如何阅读本书
  5. 勘误和支持
  6. 致谢
  7. 第一部分 走近Java
  8. 第1章 走近Java
  9. 1.4.1 Sun Classic/Exact VM
  10. 1.4.2 Sun HotSpot VM
  11. 1.4.3 Sun Mobile-Embedded VM/Meta-Circular VM
  12. 1.4.4 BEA JRockit/IBM J9 VM
  13. 1.4.5 Azul VM/BEA Liquid VM
  14. 1.4.6 Apache Harmony/Google Android Dalvik VM
  15. 1.4.7 Microsoft JVM及其他
  16. 1.5.1 模块化
  17. 1.5.2 混合语言
  18. 1.5.3 多核并行
  19. 1.5.4 进一步丰富语法
  20. 1.5.5 64位虚拟机
  21. 1.6.1 获取JDK源码
  22. 1.6.2 系统需求
  23. 1.6.3 构建编译环境
  24. 1.6.4 进行编译
  25. 1.6.5 在IDE工具中进行源码调试
  26. 第二部分 自动内存管理机制
  27. 第2章 Java内存区域与内存溢出异常
  28. 2.2.1 程序计数器
  29. 2.2.2 Java虚拟机栈
  30. 2.2.3 本地方法栈
  31. 2.2.4 Java堆
  32. 2.2.5 方法区
  33. 2.2.6 运行时常量池
  34. 2.2.7 直接内存
  35. 2.3.1 对象的创建
  36. 2.3.2 对象的内存布局
  37. 2.3.3 对象的访问定位
  38. 2.4.1 Java堆溢出
  39. 2.4.2 虚拟机栈和本地方法栈溢出
  40. 2.4.3 方法区和运行时常量池溢出
  41. 2.4.4 本机直接内存溢出
  42. 第3章 垃圾收集器与内存分配策略
  43. 3.2.1 引用计数算法
  44. 3.2.2 可达性分析算法
  45. 3.2.3 再谈引用
  46. 3.2.4 生存还是死亡
  47. 3.2.5 回收方法区
  48. 3.3.1 标记-清除算法
  49. 3.3.2 复制算法
  50. 3.3.3 标记-整理算法
  51. 3.3.4 分代收集算法
  52. 3.4.1 枚举根节点
  53. 3.4.2 安全点
  54. 3.4.3 安全区域
  55. 3.5.1 Serial收集器
  56. 3.5.2 ParNew收集器
  57. 3.5.3 Parallel Scavenge收集器
  58. 3.5.4 Serial Old收集器
  59. 3.5.5 Parallel Old收集器
  60. 3.5.6 CMS收集器
  61. 3.5.7 G1收集器
  62. 3.5.8 理解GC日志
  63. 3.5.9 垃圾收集器参数总结
  64. 3.6.1 对象优先在Eden分配
  65. 3.6.2 大对象直接进入老年代
  66. 3.6.3 长期存活的对象将进入老年代
  67. 3.6.4 动态对象年龄判定
  68. 3.6.5 空间分配担保
  69. 第4章 虚拟机性能监控与故障处理工具
  70. 4.2.1 jps:虚拟机进程状况工具
  71. 4.2.2 jstat:虚拟机统计信息监视工具
  72. 4.2.3 jinfo:Java配置信息工具
  73. 4.2.4 jmap:Java内存映像工具
  74. 4.2.5 jhat:虚拟机堆转储快照分析工具
  75. 4.2.6 jstack:Java堆栈跟踪工具
  76. 4.2.7 HSDIS:JIT生成代码反汇编
  77. 4.3.1 JConsole:Java监视与管理控制台
  78. 4.3.2 VisualVM:多合一故障处理工具
  79. 第5章 调优案例分析与实战
  80. 5.2.1 高性能硬件上的程序部署策略
  81. 5.2.2 集群间同步导致的内存溢出
  82. 5.2.3 堆外内存导致的溢出错误
  83. 5.2.4 外部命令导致系统缓慢
  84. 5.2.5 服务器JVM进程崩溃
  85. 5.2.6 不恰当数据结构导致内存占用过大
  86. 5.2.7 由Windows虚拟内存导致的长时间停顿
  87. 5.3.1 调优前的程序运行状态
  88. 5.3.2 升级JDK 1.6的性能变化及兼容问题
  89. 5.3.3 编译时间和类加载时间的优化
  90. 5.3.4 调整内存设置控制垃圾收集频率
  91. 5.3.5 选择收集器降低延迟
  92. 第三部分 虚拟机执行子系统
  93. 第6章 类文件结构
  94. 6.3.1 魔数与Class文件的版本
  95. 6.3.2 常量池
  96. 6.3.3 访问标志
  97. 6.3.4 类索引、父类索引与接口索引集合
  98. 6.3.5 字段表集合
  99. 6.3.6 方法表集合
  100. 6.3.7 属性表集合
  101. 6.4.1 字节码与数据类型
  102. 6.4.2 加载和存储指令
  103. 6.4.3 运算指令
  104. 6.4.4 类型转换指令
  105. 6.4.5 对象创建与访问指令
  106. 6.4.6 操作数栈管理指令
  107. 6.4.7 控制转移指令
  108. 6.4.8 方法调用和返回指令
  109. 6.4.9 异常处理指令
  110. 6.4.10 同步指令
  111. 第7章 虚拟机类加载机制
  112. 7.3.1 加载
  113. 7.3.2 验证
  114. 7.3.3 准备
  115. 7.3.4 解析
  116. 7.3.5 初始化
  117. 7.4.1 类与类加载器
  118. 7.4.2 双亲委派模型
  119. 7.4.3 破坏双亲委派模型
  120. 第8章 虚拟机字节码执行引擎
  121. 8.2.1 局部变量表
  122. 8.2.2 操作数栈
  123. 8.2.3 动态连接
  124. 8.2.4 方法返回地址
  125. 8.2.5 附加信息
  126. 8.3.1 解析
  127. 8.3.2 分派
  128. 8.3.3 动态类型语言支持
  129. 8.4.1 解释执行
  130. 8.4.2 基于栈的指令集与基于寄存器的指令集
  131. 8.4.3 基于栈的解释器执行过程
  132. 第9章 类加载及执行子系统的案例与实战
  133. 9.2.1 Tomcat:正统的类加载器架构
  134. 9.2.2 OSGi:灵活的类加载器架构
  135. 9.2.3 字节码生成技术与动态代理的实现
  136. 9.2.4 Retrotranslator:跨越JDK版本
  137. 9.3.1 目标
  138. 9.3.2 思路
  139. 9.3.3 实现
  140. 9.3.4 验证
  141. 第四部分 程序编译与代码优化
  142. 第10章 早期(编译期)优化
  143. 10.2.1 Javac的源码与调试
  144. 10.2.2 解析与填充符号表
  145. 10.2.3 注解处理器
  146. 10.2.4 语义分析与字节码生成
  147. 10.3.1 泛型与类型擦除
  148. 10.3.2 自动装箱、拆箱与遍历循环
  149. 10.3.3 条件编译
  150. 10.4.1 实战目标
  151. 10.4.2 代码实现
  152. 10.4.3 运行与测试
  153. 10.4.4 其他应用案例
  154. 第11章 晚期(运行期)优化
  155. 11.2.1 解释器与编译器
  156. 11.2.2 编译对象与触发条件
  157. 11.2.3 编译过程
  158. 11.2.4 查看及分析即时编译结果
  159. 11.3.1 优化技术概览
  160. 11.3.2 公共子表达式消除
  161. 11.3.3 数组边界检查消除
  162. 11.3.4 方法内联
  163. 11.3.5 逃逸分析
  164. 第五部分 高效并发
  165. 第12章 Java内存模型与线程
  166. 12.3.1 主内存与工作内存
  167. 12.3.2 内存间交互操作
  168. 12.3.3 对于volatile型变量的特殊规则
  169. 12.3.4 对于long和double型变量的特殊规则
  170. 12.3.5 原子性、可见性与有序性
  171. 12.3.6 先行发生原则
  172. 12.4.1 线程的实现
  173. 12.4.2 Java线程调度
  174. 12.4.3 状态转换
  175. 第13章 线程安全与锁优化
  176. 13.2.1 Java语言中的线程安全
  177. 13.2.2 线程安全的实现方法
  178. 13.3.1 自旋锁与自适应自旋
  179. 13.3.2 锁消除
  180. 13.3.3 锁粗化
  181. 13.3.4 轻量级锁
  182. 13.3.5 偏向锁
  183. 附录
  184. 附录A 编译Windows版的OpenJDK
  185. 附录B 虚拟机字节码指令表
  186. 附录C HotSpot虚拟机主要参数表
  187. 附录D 对象查询语言(OQL)简介
  188. 附录E JDK历史版本轨迹

作者周志明

类别 图书 / 非虚构

出版社机械工业出版社

出版日期

ISBN9787111421900

提供方华章数媒

标签计算机(1388)编程(372)IT(198)Java(37)JVM(2)

喜欢这本书的人也喜欢

来自豆瓣读书的评论30