欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > 文章正文

《深入理解Java虚拟机》第2版笔记(完整),

来源: javaer 分享于  点击 32223 次 点评:70

《深入理解Java虚拟机》第2版笔记(完整),


第1章 走近Java

1.2 Java技术体系

1.4 Java虚拟机发展史

1.4.1 Sun Classic / Exact VM

1.4.2 Sun HotSpot VM

1.4.6 Apache Harmony / Google Android Dalvik VM

1.5 展望Java技术的未来

第2章 Java内存区域与内存溢出异常

2.2 运行时数据区域

2.2.4 Java堆

2.2.5 方法区

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 方法区和运行时常量池溢出

第3章 垃圾收集器与内存分配策略

3.1 概述

3.2 对象已死吗

3.2.2 可达性分析算法

3.2.4 生存还是死亡

3.4 HotSpot算法实现

3.4.2 安全点

3.4.3 安全区域

3.5 垃圾收集器

3.5.1 Serial收集器

3.5.3 Parallel Scavenge收集器

3.5.6 CMS收集器

3.5.7 G1收集器

3.6 内存分配与回收策略

3.6.2 大对象直接进入老年代

3.6.5 空间分配担保

第4章 虚拟机性能监控与故障处理工具

4.2 JDK的命令行工具

4.2.4 jmap: Java内存映像工具

4.3 JDK的可视化工具

4.3.1 JConsole: Java监视与管理控制台

第5章 调优案例分析与实战

5.2 案例分析

5.2.1 高性能硬件上的程序部署策略

5.2.3 堆外内存导致的溢出错误

5.2.4 外部命令导致系统缓慢

5.2.6 不恰当数据结构导致内存占用过大

5.3 实战:Eclipse运行速度调优

5.3.3 编译时间和类加载时间的优化

5.3.4 调整内存设置控制垃圾收集频率

第6章 类文件结构

6.2 无关性的基石

6.3 Class文件的结构

6.3.1 魔数与Class文件的版本

6.3.2 常量池

6.3.6 方法表集合

6.3.7 属性表集合

6.4 字节码指令简介

6.4.10 同步指令

6.5 公有设计和私有实现

第7章 虚拟机类加载机制

7.2 类加载的时机

7.3 类加载的过程

7.3.1 加载

7.3.2 验证

7.3.3 准备

7.4 类加载器

7.4.1 类与类加载器

7.4.2 双亲委派模型

protected synchronized Class<?> loadClass(String name, boolean resolve) throws ClassNotFoundException {
    Class c = findLoadedClass(name);
    if (c==null) {
        try {
            if (parent!=null) 
                c = parent.loadClass(name, false);
            else
                c = findBootstrapClassOrNull(name);
        } catch (ClassNotFoundException e)
        {}
        if (c==null)
            findClass(name);
    }
    if (resolve)
        resolveClass(c);
    return c;
}

7.4.3 破坏双亲委派模型

第8章 虚拟机字节码执行引擎

8.2 运行时栈帧结构

8.2.1 局部变量表

8.2.2 操作数栈

8.3 方法调用

8.3.1 解析

8.3.2 分派

8.3.3 动态类型语言支持

8.4 基于栈的字节码解释执行引擎

8.4.1 解释执行

8.4.2 基于栈的指令集与基于寄存器的指令集

第9章 类加载及执行子系统的案例与实战

9.2 案例分析

9.2.1 Tomcat: 正统的类加载器架构

9.2.2 OSGi: 灵活的类加载器架构

9.2.4 Retrotranslator: 跨越JDK版本

9.3 实战:自己动手实现远程执行功能

9.3.2 思路

第10章 早期(编译期)优化

10.1 概述

10.2 Javac编译器

10.2.4 语义分析与字节码生成

10.3 Java语法糖的味道

10.3.1 泛型与类型擦除

自动装箱、拆箱与遍历循环

10.4 实战:插入式注解处理器

10.4.2 代码实现

第11章 晚期(运行期)优化

11.2 HotSpot虚拟机内的即时编译器

11.2.1 解释器与编译器

11.2.2 编译对象与触发条件

11.2.3 编译过程

11.2.4 查看及分析即时编译结果

11.3 编译优化技术

11.3.3 数组边界检查消除

if (foo!=null) {
    return foo.value;
} else {
    throw new NullPointException();
}

try {
    return foo.value;
} catch(segment_fault) {
    uncommon_trap();
}

11.3.4 方法内联

11.3.5 逃逸分析

11.4 Java与C/C++的编译器对比

第12章 Java内存模型与线程

12.2 硬件的效率与一致性

12.3 Java内存模型

12.3.1 主内存与工作内存

12.3.3 对于volatile型变量的特殊规则

public class Singleton {
    private volatile static Singleton instance;
    public static Singleton getInstance() {
        if (instance==null) {
            synchronized(Singleton.class) {
                if(instance==null) {
                    instance = new Singleton();
                }
            }
        return instance;
    }
}

12.3.5 原子性、可见性与有序性

12.4 Java与线程

12.4.1 线程的实现

12.4.2 Java线程调度

12.4.3 状态转换

第13章 线程安全与锁优化

13.2 线程安全

13.2.1 Java语言中的线程安全

13.2.2 线程安全的实现方法

public final int incrementAndGet() {
    for(;;) {
        int current = get();
        int next = current + 1;
        if (compareAndSet(current, next))
            return next;
    }
}

13.3 锁优化

13.3.1 自旋锁与自适应自旋

13.3.3 锁粗化

13.3.4 轻量级锁

相关文章

    暂无相关文章
相关栏目:

用户点评