深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)

深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
8.9
分享
扫描下方二维码分享到微信
打开微信,点击右上角”+“,
使用”扫一扫“即可将网页分享到朋友圈。
作者:
出版社: 机械工业出版社
2013-05
版次: 2
ISBN: 9787111421900
定价: 79.00
装帧: 平装
开本: 16开
纸张: 胶版纸
页数: 452页
正文语种: 简体中文
原版书名: Understanding the JVM:Advanced Features and Best Practices
  •   本书第1版两年内印刷近10次,4家网上书店的评论近4?000条,98%以上的评论全部为5星级的好评,是整个Java图书领域公认的经典著作和超级畅销书,繁体版在台湾也十分受欢迎。第2版在第1版的基础上做了很大的改进:根据全新的JDK 1.7对全书内容进行了全面的升级和补充;增加了大量处理各种常见JVM问题的技巧和优佳实践;增加了若干与生产环境相结合的实战案例;对第1版中的错误和不足之处的修正;等等。第2版不仅技术更新、内容更丰富,而且实战性更强。  本书共分为五大部分,围绕内存管理、执行子系统、程序编译与优化、高效并发等核心主题对JVM进行了全面而深入的分析,深刻揭示了JVM的工作原理。第一部分从宏观的角度介绍了整个Java技术体系、Java和JVM的发展历程、模块化,以及JDK的编译,这对理解本书后面内容有重要帮助。第二部分讲解了JVM的自动内存管理,包括虚拟机内存区域的划分原理以及各种内存溢出异常产生的原因;常见的垃圾收集算法以及垃圾收集器的特点和工作原理;常见虚拟机监控与故障处理工具的原理和使用方法。第三部分分析了虚拟机的执行子系统,包括类文件结构、虚拟机类加载机制、虚拟机字节码执行引擎。第四部分讲解了程序的编译与代码的优化,阐述了泛型、自动装箱拆箱、条件编译等语法糖的原理;讲解了虚拟机的热点探测方法、HotSpot的即时编译器、编译触发条件,以及如何从虚拟机外部观察和分析JIT编译的数据和结果;第五部分探讨了Java实现高效并发的原理,包括JVM内存模型的结构和操作;原子性、可见性和有序性在Java内存模型中的体现;先行发生原则的规则和使用;线程在Java语言中的实现原理;虚拟机实现高效并发所做的一系列锁优化措施。   周志明,资深Java技术专家,对JavaEE企业级应用开发、OSGi、Java虚拟机和工作流等都有深入的研究,并在大量的实践中积累了丰富的经验。尤其精通Java虚拟机,撰写了大量与JVM相关的经典文章,被各大技术社区争相转载,是ITeye等技术社区公认的Java虚拟机方面的领袖人物之一。除本书外,还著有经典著作本书,广获读者好评。现任远光软件股份有限公司开发部总经理兼架构师,先后参与过国家电网、南方电网等多个大型ERP项目的平台架构工作,对软件系统架构也有深刻的认识和体会。 前言第一部分 走近Java第1章 走近Java1.1 概述1.2 Java技术体系1.3 Java发展史1.4 Java虚拟机发展史1.4.1 Sun Classic Exact VM1.4.2 Sun HotSpot VM1.4.3 Sun Mobile-Embedded VM Meta-Circular VM1.4.4 BEA JRockit IBM J9 VM1.4.5 Azul VM BEA Liquid VM1.4.6 Apache Harmony Google Android Dalvik VM1.4.7 Microsoft JVM及其他1.5 展望Java技术的未来1.5.1 模块化1.5.2 混合语言1.5.3 多核并行1.5.4 进一步丰富语法1.5.5 64位虚拟机1.6 实战:自己编译JDK1.6.1 获取JDK源码1.6.2 系统需求1.6.3 构建编译环境1.6.4 进行编译1.6.5 在IDE工具中进行源码调试1.7 本章小结第二部分 自动内存管理机制第2章 Java内存区域与内存溢出异常2.1 概述2.2 运行时数据区域2.2.1 程序计数器2.2.2 Java虚拟机栈2.2.3 本地方法栈2.2.4 Java堆2.2.5 方法区2.2.6 运行时常量池2.2.7 直接内存2.3 HotSpot虚拟机对象探秘2.3.1 对象的创建2.3.2 对象的内存布局2.3.3 对象的访问定位2.4 实战:OutOfMemoryError异常2.4.1 Java堆溢出2.4.2 虚拟机栈和本地方法栈溢出2.4.3 方法区和运行时常量池溢出2.4.4 本机直接内存溢出2.5 本章小结第3章 垃圾收集器与内存分配策略3.1 概述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 HotSpot的算法实现3.4.1 枚举根节点3.4.2 安全点3.4.3 安全区域3.5 垃圾收集器3.5.1 Serial收集器3.5.2 ParNew收集器3.5.3 Parallel Scavenge收集器3.5.4 Serial Old收集器3.5.5 Parallel Old收集器3.5.6 CMS收集器3.5.7 G1收集器3.5.8 理解GC日志3.5.9 垃圾收集器参数总结3.6 内存分配与回收策略3.6.1 对象优先在Eden分配3.6.2 大对象直接进入老年代3.6.3 长期存活的对象将进入老年代3.6.4 动态对象年龄判定3.6.5 空间分配担保3.7 本章小结第4章 虚拟机性能监控与故障处理工具4.1 概述4.2 JDK的命令行工具4.2.1 jps:虚拟机进程状况工具4.2.2 jstat:虚拟机统计信息监视工具4.2.3 jinfo:Java配置信息工具4.2.4 jmap:Java内存映像工具4.2.5 jhat:虚拟机堆转储快照分析工具4.2.6 jstack:Java堆栈跟踪工具4.2.7 HSDIS:JIT生成代码反汇编4.3 JDK的可视化工具4.3.1 JConsole:Java监视与管理控制台4.3.2 VisualVM:多合一故障处理工具4.4 本章小结第5章 调优案例分析与实战5.1 概述5.2 案例分析5.2.1 高性能硬件上的程序部署策略5.2.2 集群间同步导致的内存溢出5.2.3 堆外内存导致的溢出错误5.2.4 外部命令导致系统缓慢5.2.5 服务器JVM进程崩溃5.2.6 不恰当数据结构导致内存占用过大5.2.7 由Windows虚拟内存导致的长时间停顿5.3 实战:Eclipse运行速度调优5.3.1 调优前的程序运行状态5.3.2 升级JDK 1.6的性能变化及兼容问题5.3.3 编译时间和类加载时间的优化5.3.4 调整内存设置控制垃圾收集频率5.3.5 选择收集器降低延迟5.4 本章小结第三部分 虚拟机执行子系统第6章 类文件结构6.1 概述6.2 无关性的基石6.3 Class类文件的结构6.3.1 魔数与Class文件的版本6.3.2 常量池6.3.3 访问标志6.3.4 类索引、父类索引与接口索引集合6.3.5 字段表集合6.3.6 方法表集合6.3.7 属性表集合6.4 字节码指令简介6.4.1 字节码与数据类型6.4.2 加载和存储指令6.4.3 运算指令6.4.4 类型转换指令6.4.5 对象创建与访问指令6.4.6 操作数栈管理指令6.4.7 控制转移指令6.4.8 方法调用和返回指令6.4.9 异常处理指令6.4.10 同步指令6.5 公有设计和私有实现6.6 Class文件结构的发展6.7 本章小结第7章 虚拟机类加载机制7.1 概述7.2 类加载的时机7.3 类加载的过程7.3.1 加载7.3.2 验证7.3.3 准备7.3.4 解析7.3.5 初始化7.4 类加载器7.4.1 类与类加载器7.4.2 双亲委派模型7.4.3 破坏双亲委派模型7.5 本章小结第8章 虚拟机字节码执行引擎8.1 概述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.4 基于栈的字节码解释执行引擎8.4.1 解释执行8.4.2 基于栈的指令集与基于寄存器的指令集8.4.3 基于栈的解释器执行过程8.5 本章小结第9章 类加载及执行子系统的案例与实战9.1 概述9.2 案例分析9.2.1 Tomcat:正统的类加载器架构9.2.2 OSGi:灵活的类加载器架构9.2.3 字节码生成技术与动态代理的实现9.2.4 Retrotranslator:跨越JDK版本9.3 实战:自己动手实现远程执行功能9.3.1 目标9.3.2 思路9.3.3 实现9.3.4 验证9.4 本章小结第四部分 程序编译与代码优化第10章 早期(编译期)优化10.1 概述10.2 Javac编译器10.2.1 Javac的源码与调试10.2.2 解析与填充符号表10.2.3 注解处理器10.2.4 语义分析与字节码生成10.3 Java语法糖的味道10.3.1 泛型与类型擦除10.3.2 自动装箱、拆箱与遍历循环10.3.3 条件编译10.4 实战:插入式注解处理器10.4.1 实战目标10.4.2 代码实现10.4.3 运行与测试10.4.4 其他应用案例10.5 本章小结第11章 晚期(运行期)优化11.1 概述11.2 HotSpot虚拟机内的即时编译器11.2.1 解释器与编译器11.2.2 编译对象与触发条件11.2.3 编译过程11.2.4 查看及分析即时编译结果11.3 编译优化技术11.3.1 优化技术概览11.3.2 公共子表达式消除11.3.3 数组边界检查消除11.3.4 方法内联11.3.5 逃逸分析11.4 Java与CC++的编译器对比11.5 本章小结第五部分 高效并发第12章 Java内存模型与线程12.1 概述12.2 硬件的效率与一致性12.3 Java内存模型12.3.1 主内存与工作内存12.3.2 内存间交互操作12.3.3 对于volatile型变量的特殊规则12.3.4 对于long和double型变量的特殊规则12.3.5 原子性、可见性与有序性12.3.6 先行发生原则12.4 Java与线程12.4.1 线程的实现12.4.2 Java线程调度12.4.3 状态转换12.5 本章小结第13章 线程安全与锁优化13.1 概述13.2 线程安全13.2.1 Java语言中的线程安全13.2.2 线程安全的实现方法13.3 锁优化13.3.1 自旋锁与自适应自旋13.3.2 锁消除13.3.3 锁粗化13.3.4 轻量级锁13.3.5 偏向锁13.4 本章小结附  录附录A 编译Windows版的OpenJDK附录B 虚拟机字节码指令表附录C HotSpot虚拟机主要参数表附录D 对象查询语言(OQL)简介附录E JDK历史版本轨迹
  • 内容简介:
      本书第1版两年内印刷近10次,4家网上书店的评论近4?000条,98%以上的评论全部为5星级的好评,是整个Java图书领域公认的经典著作和超级畅销书,繁体版在台湾也十分受欢迎。第2版在第1版的基础上做了很大的改进:根据全新的JDK 1.7对全书内容进行了全面的升级和补充;增加了大量处理各种常见JVM问题的技巧和优佳实践;增加了若干与生产环境相结合的实战案例;对第1版中的错误和不足之处的修正;等等。第2版不仅技术更新、内容更丰富,而且实战性更强。  本书共分为五大部分,围绕内存管理、执行子系统、程序编译与优化、高效并发等核心主题对JVM进行了全面而深入的分析,深刻揭示了JVM的工作原理。第一部分从宏观的角度介绍了整个Java技术体系、Java和JVM的发展历程、模块化,以及JDK的编译,这对理解本书后面内容有重要帮助。第二部分讲解了JVM的自动内存管理,包括虚拟机内存区域的划分原理以及各种内存溢出异常产生的原因;常见的垃圾收集算法以及垃圾收集器的特点和工作原理;常见虚拟机监控与故障处理工具的原理和使用方法。第三部分分析了虚拟机的执行子系统,包括类文件结构、虚拟机类加载机制、虚拟机字节码执行引擎。第四部分讲解了程序的编译与代码的优化,阐述了泛型、自动装箱拆箱、条件编译等语法糖的原理;讲解了虚拟机的热点探测方法、HotSpot的即时编译器、编译触发条件,以及如何从虚拟机外部观察和分析JIT编译的数据和结果;第五部分探讨了Java实现高效并发的原理,包括JVM内存模型的结构和操作;原子性、可见性和有序性在Java内存模型中的体现;先行发生原则的规则和使用;线程在Java语言中的实现原理;虚拟机实现高效并发所做的一系列锁优化措施。
  • 作者简介:
      周志明,资深Java技术专家,对JavaEE企业级应用开发、OSGi、Java虚拟机和工作流等都有深入的研究,并在大量的实践中积累了丰富的经验。尤其精通Java虚拟机,撰写了大量与JVM相关的经典文章,被各大技术社区争相转载,是ITeye等技术社区公认的Java虚拟机方面的领袖人物之一。除本书外,还著有经典著作本书,广获读者好评。现任远光软件股份有限公司开发部总经理兼架构师,先后参与过国家电网、南方电网等多个大型ERP项目的平台架构工作,对软件系统架构也有深刻的认识和体会。
  • 目录:
    前言第一部分 走近Java第1章 走近Java1.1 概述1.2 Java技术体系1.3 Java发展史1.4 Java虚拟机发展史1.4.1 Sun Classic Exact VM1.4.2 Sun HotSpot VM1.4.3 Sun Mobile-Embedded VM Meta-Circular VM1.4.4 BEA JRockit IBM J9 VM1.4.5 Azul VM BEA Liquid VM1.4.6 Apache Harmony Google Android Dalvik VM1.4.7 Microsoft JVM及其他1.5 展望Java技术的未来1.5.1 模块化1.5.2 混合语言1.5.3 多核并行1.5.4 进一步丰富语法1.5.5 64位虚拟机1.6 实战:自己编译JDK1.6.1 获取JDK源码1.6.2 系统需求1.6.3 构建编译环境1.6.4 进行编译1.6.5 在IDE工具中进行源码调试1.7 本章小结第二部分 自动内存管理机制第2章 Java内存区域与内存溢出异常2.1 概述2.2 运行时数据区域2.2.1 程序计数器2.2.2 Java虚拟机栈2.2.3 本地方法栈2.2.4 Java堆2.2.5 方法区2.2.6 运行时常量池2.2.7 直接内存2.3 HotSpot虚拟机对象探秘2.3.1 对象的创建2.3.2 对象的内存布局2.3.3 对象的访问定位2.4 实战:OutOfMemoryError异常2.4.1 Java堆溢出2.4.2 虚拟机栈和本地方法栈溢出2.4.3 方法区和运行时常量池溢出2.4.4 本机直接内存溢出2.5 本章小结第3章 垃圾收集器与内存分配策略3.1 概述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 HotSpot的算法实现3.4.1 枚举根节点3.4.2 安全点3.4.3 安全区域3.5 垃圾收集器3.5.1 Serial收集器3.5.2 ParNew收集器3.5.3 Parallel Scavenge收集器3.5.4 Serial Old收集器3.5.5 Parallel Old收集器3.5.6 CMS收集器3.5.7 G1收集器3.5.8 理解GC日志3.5.9 垃圾收集器参数总结3.6 内存分配与回收策略3.6.1 对象优先在Eden分配3.6.2 大对象直接进入老年代3.6.3 长期存活的对象将进入老年代3.6.4 动态对象年龄判定3.6.5 空间分配担保3.7 本章小结第4章 虚拟机性能监控与故障处理工具4.1 概述4.2 JDK的命令行工具4.2.1 jps:虚拟机进程状况工具4.2.2 jstat:虚拟机统计信息监视工具4.2.3 jinfo:Java配置信息工具4.2.4 jmap:Java内存映像工具4.2.5 jhat:虚拟机堆转储快照分析工具4.2.6 jstack:Java堆栈跟踪工具4.2.7 HSDIS:JIT生成代码反汇编4.3 JDK的可视化工具4.3.1 JConsole:Java监视与管理控制台4.3.2 VisualVM:多合一故障处理工具4.4 本章小结第5章 调优案例分析与实战5.1 概述5.2 案例分析5.2.1 高性能硬件上的程序部署策略5.2.2 集群间同步导致的内存溢出5.2.3 堆外内存导致的溢出错误5.2.4 外部命令导致系统缓慢5.2.5 服务器JVM进程崩溃5.2.6 不恰当数据结构导致内存占用过大5.2.7 由Windows虚拟内存导致的长时间停顿5.3 实战:Eclipse运行速度调优5.3.1 调优前的程序运行状态5.3.2 升级JDK 1.6的性能变化及兼容问题5.3.3 编译时间和类加载时间的优化5.3.4 调整内存设置控制垃圾收集频率5.3.5 选择收集器降低延迟5.4 本章小结第三部分 虚拟机执行子系统第6章 类文件结构6.1 概述6.2 无关性的基石6.3 Class类文件的结构6.3.1 魔数与Class文件的版本6.3.2 常量池6.3.3 访问标志6.3.4 类索引、父类索引与接口索引集合6.3.5 字段表集合6.3.6 方法表集合6.3.7 属性表集合6.4 字节码指令简介6.4.1 字节码与数据类型6.4.2 加载和存储指令6.4.3 运算指令6.4.4 类型转换指令6.4.5 对象创建与访问指令6.4.6 操作数栈管理指令6.4.7 控制转移指令6.4.8 方法调用和返回指令6.4.9 异常处理指令6.4.10 同步指令6.5 公有设计和私有实现6.6 Class文件结构的发展6.7 本章小结第7章 虚拟机类加载机制7.1 概述7.2 类加载的时机7.3 类加载的过程7.3.1 加载7.3.2 验证7.3.3 准备7.3.4 解析7.3.5 初始化7.4 类加载器7.4.1 类与类加载器7.4.2 双亲委派模型7.4.3 破坏双亲委派模型7.5 本章小结第8章 虚拟机字节码执行引擎8.1 概述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.4 基于栈的字节码解释执行引擎8.4.1 解释执行8.4.2 基于栈的指令集与基于寄存器的指令集8.4.3 基于栈的解释器执行过程8.5 本章小结第9章 类加载及执行子系统的案例与实战9.1 概述9.2 案例分析9.2.1 Tomcat:正统的类加载器架构9.2.2 OSGi:灵活的类加载器架构9.2.3 字节码生成技术与动态代理的实现9.2.4 Retrotranslator:跨越JDK版本9.3 实战:自己动手实现远程执行功能9.3.1 目标9.3.2 思路9.3.3 实现9.3.4 验证9.4 本章小结第四部分 程序编译与代码优化第10章 早期(编译期)优化10.1 概述10.2 Javac编译器10.2.1 Javac的源码与调试10.2.2 解析与填充符号表10.2.3 注解处理器10.2.4 语义分析与字节码生成10.3 Java语法糖的味道10.3.1 泛型与类型擦除10.3.2 自动装箱、拆箱与遍历循环10.3.3 条件编译10.4 实战:插入式注解处理器10.4.1 实战目标10.4.2 代码实现10.4.3 运行与测试10.4.4 其他应用案例10.5 本章小结第11章 晚期(运行期)优化11.1 概述11.2 HotSpot虚拟机内的即时编译器11.2.1 解释器与编译器11.2.2 编译对象与触发条件11.2.3 编译过程11.2.4 查看及分析即时编译结果11.3 编译优化技术11.3.1 优化技术概览11.3.2 公共子表达式消除11.3.3 数组边界检查消除11.3.4 方法内联11.3.5 逃逸分析11.4 Java与CC++的编译器对比11.5 本章小结第五部分 高效并发第12章 Java内存模型与线程12.1 概述12.2 硬件的效率与一致性12.3 Java内存模型12.3.1 主内存与工作内存12.3.2 内存间交互操作12.3.3 对于volatile型变量的特殊规则12.3.4 对于long和double型变量的特殊规则12.3.5 原子性、可见性与有序性12.3.6 先行发生原则12.4 Java与线程12.4.1 线程的实现12.4.2 Java线程调度12.4.3 状态转换12.5 本章小结第13章 线程安全与锁优化13.1 概述13.2 线程安全13.2.1 Java语言中的线程安全13.2.2 线程安全的实现方法13.3 锁优化13.3.1 自旋锁与自适应自旋13.3.2 锁消除13.3.3 锁粗化13.3.4 轻量级锁13.3.5 偏向锁13.4 本章小结附  录附录A 编译Windows版的OpenJDK附录B 虚拟机字节码指令表附录C HotSpot虚拟机主要参数表附录D 对象查询语言(OQL)简介附录E JDK历史版本轨迹
查看详情
好书推荐 / 更多
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
20世纪思想史:从弗洛伊德到互联网
[英]彼得·沃森 著;杨阳 译;张凤
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
想象一朵未来的玫瑰
[葡]费尔南多·佩索阿 著;杨铁军 译
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
语言与死亡/当代激进思想家译丛
[意]吉奥乔·阿甘本 著
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
爸爸妈妈,请做我的摄影师:十万父母拍娃智慧分享儿童摄影
枫糖盒子 著
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
陈规再造:巫鸿美术史文集卷三
[美]巫鸿 著;郑岩 编
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
另一个世界:中国记忆1961-1962
[瑞典]林西莉 著;李之义 译
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
生活,在别处:海明威影像集
鲍里斯·维多夫斯基 著;吴天楚 译;[美国]玛瑞儿·海明威;高方;王天宇
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
大西洋的故事
[英]西蒙·温彻斯特(Simon Winchester) 著
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
图说勃鲁盖尔
[日]冈部纮三 著;曹逸冰 译
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
巴别塔(我要世界都听见我的声音,我曾被压抑,但绝不沉默。)(读客外国小说文库)
[英]A.S.拜厄特 著;王一鸣 译
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
四十二年,我的"恶邻"李敖大师
林恒范 著;[中国台湾]林丽蘋 口述
深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)
灭绝与演化:化石中的生命全史
[美]尼尔斯·艾崔奇 著;周亚纯 译;董丽萍