深入理解Java虚拟机三周志明
目录
前言
第2版与第1版的区别
本书面向的读者
如何阅读本书
语言约定
内容特色
参考资料
勘误和支持
致谢
第一部分走近Java
第1章走近Java
1.1概述
1.2Java技术体系
1.3Java发展史
1.4Java虚拟机发展史
1.4.1SunClassic/ExactVM
1.4.2SunHotSpotVM
4.3SunMobile-EmbeddedVM/Meta-CircularVM
1.4.4BEAJRockit/IBMJ9VM
1.4.5AzulVM/BEALiquidVM
1.4.6ApacheHarmony/GoogleAndroidDalvikVM
4.7MicrosoftJVM及其他
1.5展望Java技术的未来
1.5.1模块化
1.5.2混合语言
1.5.3多核并行
1.5.4进一步丰富语法
1.5.564位虚拟机
1.6实战:自己编译JDK
1.6.1获取JK源码
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.2Java虚拟机栈
2.2.3本地方法栈
2.2.4Jaa堆
2.2.5方法区
2.2.6运行时常量池
2.2.7直接内存
2.3Hotspot虚拟机对象探秘
2.3.1对象的创建
2.3.2对象的内存布局
2.3.3对象的访问定位
2.4实战:0utOfMemoryError异常
2.4.1Java堆溢出
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.4Hotspot的算法实现
3.4.1枚举根节点
3.4.2安全点
3.4.3安全区域
3.5垃圾收集器
3.5.1Seria收集器
3.5.2ParDew收集器
3.5.3Parallelscavenge收集器
3.5.4Serial0ld收集器
3.5.5Parallel0ld收集器
3.5.6CMS收集器
3.5.7G1收集器
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.2JDK的命令行工具
4.2.1jips:虚拟机进程状况工具
4.2.2stat:虚拟机统计信息监视工具
4.2.3jinfo:Java配置信息工具
4.2.4jmap:Java内存映像工具
4.2.5jhat:虚拟机堆转储快照分析工具
4.2.6stack:Java堆栈跟踪工具
4.2.7HSDIS:JT生成代码反汇编
4.3JDK的可视化工具
4.3.1JConsole:Java监视与管理控制台
4.3.2Visualvm:多合一故障处理工具
4.4本章小结
第5章调优案例分析与实战
5.1概述
5.2案例分析
5.2.1高性能硬件上的程序部署策略
5.2.2集群间同步导致的内存溢出
5.2.3堆外内存导致的溢出错误
5.2.4外部命令导致系统缓慢
5.2.5服务器JM进程崩溃
5.2.6不恰当数据结构导致内存占用过大
5.2.7由Windows虚拟内存导致的长时间停顿
5.3实哉:Eclipse运行速度调优
5.3.1调优前的程序运行状态
5.3.2升级JDK1.6的性能变化及兼容问题
5.3.3编译时间和类加载时间的优化
5.3.4调整内存设置控制垃圾收集频率
5.3.5选择收集器降低延迟
5.4本章小结
分
第三部
虚拟机执行子系统
第6章类文件结构
6.1概述
6.2无关性的基石
6.3Class类文件的结构
6.3.1魔数与C1ass文件的版本
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.6Cas文件结构的发展
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双亲委派模型
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.1Tomcat:正统的类加载器架构
9.2.20Gi:灵活的类加载器架构
9.2.3字节码生成技术与动态代理的实现
9.2.4Retrotranslator:跨越JDK版本
9.3实战:自己动手实现远程执行功能
9.3.1目标
9.3.2思路
9.3.3实现
9.3.4验证
9.4本章小结
第四部分程序编译与代码优化
第10章早期(编译期)优化
10.1概述
10.2Javac编译器
10.2.1Javac的源码与调试
10.2.2解析与填充符号表
10.2.3注解处理器
10.2.4语义分析与字节码生成
10.3Java语法糖的味道
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.2Hotspot虚拟机内的即时编译器
11.2.1解释器与编译器
11.2.2编译对象与触发条件
11.2.3编译过程
1.2.4查看及分析即时编译结果
1.3编译优化技术
11.3.1优化技术概览
11.3.2公共子表达式消除
11.3.3数组边界检查消除
11.3.4方法内联
11.3.5逃逸分析
11.4Java与C/C++的编译器对比
11.5本章小结
第五部分高效并发
第12章Java内存模型与线程
12.1概述
12.2硬件的效率与一致性
12.3Java内存模型
12.3.1主内存与工作内存
12.3.2内存间交互操作
12.3.3对于volatile型变量的特殊规则
12.3.4对于1ong和double型变量的特殊规则
12.3.5原子性、可见性与有序性
12.3.6先行发生原则
12.4Java与线程
12.4.1线程的实现
12.4.2Java线程调度
12.4.3状态转换
12.5本章小结
第13章线程安全与锁优化
13.1概述
13.2线程安全
13.2.1Java语言中的线程安全
13.2.2线程安全的实现方法
13.3锁优化
13.3.1自旋锁与自适应自旋
13.3.2锁消除
13.3.3锁粗化
13.3.4轻量级锁
13.3.5偏向锁
13.4本章小结
附录
附录A编译Windows版的OpendK
暂无评论