总目录:
Java虚拟机 - 随笔分类 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/category/731395.html
已读:
Java虚拟机1:什么是Java - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4826691.html
注:初步了解JAVA虚拟机,只是说明介绍,没有太多实际东西。
Java虚拟机2:Java内存区域及对象 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4827590.html
注:初步讲解了堆和栈的含义,以及内存说明。后面讲了对象创建时内存的分配,以及如何对象寻址,比价重要。
Java虚拟机3:常用JVM命令参数 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4830692.html
注:主要讲了常用JVM命令参数的含义。
Java虚拟机4:内存溢出 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4833713.html
注:主要讲了内存溢出:堆溢出、栈溢出,以及方法区和运行时常量池溢出,了解一下。
Java虚拟机5:Java垃圾回收(GC)机制详解 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4836700.html
注:介绍了垃圾回收算法,垃圾收集器,以及垃圾收集的实例代码讲解,还有如何观看GC日志。如果深入学习,那么这一块很需要好好看看。
Java虚拟机6:内存溢出和内存泄露、并行和并发、Minor GC和Full GC、Client模式和Server模式的区别 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4839245.html
注:主要介绍概念,标题中的。其他主要讲解Client模式和Server模式的区别:主要是不同模式下使用不同的JIT编译器。
Java虚拟机7:内存分配原则 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4841177.html
注:主要讲了内存分配原则,即新建对象优先分配在新生代还是老年代,如果新生代GC或者老年代FGC,内存是如何转移的,以及一些内存分配原则说明。
Java虚拟机8:虚拟机性能监控与故障处理工具 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4842483.html
注:主要讲了查询虚拟机一些基本信息的常用命令,有了这些命令我们才能获取到虚拟机具体的状态,才能发现问题,然后解决问题。
另外,简单提了一些其他工具:JDK自带的,以及一些付费工具等。后续实际分析时可以参考。
Java虚拟机9:Java类加载机制 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4844915.html
注:类使用的7个阶段:加载(Loading)、验证(Verification)、准备(Preparation)、解析(Resolution)、初始化(Initiallization)、使用(Using)和卸载(Unloading)这7个阶段。
每个阶段分别做了一些重要说明。不是很理解,不过可以先记着,后续需要再细看。
Java虚拟机10:类加载器 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4845144.html
注:主要介绍了类加载器,主要就是如何对类加载,是第九篇文章里加载部分的比较详细的讲解。
不做笔记,后续有需要直接看原文。
Java虚拟机11:运行期优化 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4857820.html
注:这篇文章主要详细讲了运行期优化,即JIT即时编译相关,主要是如何确定需要进行即时编译:方法调用计数器和回边计数器;另外还有编译过程中的优化技术:公共子表达式消除,数组范围检查消除和方法内联以及逃逸分析。可以简单理解一下。
Java虚拟机12:Java内存模型 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4859107.html
注:这一章主要是讲了多线程相关,因为内存模型对多线程影响很大,主要想说明了两个内存:主内存和工作内存。以及两种内存之间的交互(原子性操作),以及一些交互规则。
最后,顺带说了volatile关键字的作用和synchronized关键字的作用。
还有先行发生happens-before原则:一共8个。线程之间的安全问题可以通过这八个原则来进行判断。
Java虚拟机13:互斥同步、锁优化及synchronized和volatile - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4978876.html
注:互斥是因,同步是果;互斥是方法,同步是目的。
另外主要从编译的字节码层次讲了:synchronized的实现和volatile的实现。
Java虚拟机14:Java对象大小、对象内存布局及锁状态变化 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/6928133.html
注:一个对象占多少字节,除了基本数据类型的字节数,还有不同操作系统保存对象元数据的内存。这些内容加起来,才是一个对象占用的全部字节。
还讲了JAVA的四种锁的状态:无锁态、偏向锁、轻量级锁和重量级锁。详细介绍了每种锁的优点,以及在什么情况下,锁会由次一级升级为高一级的锁。
Java虚拟机15:再谈四种引用状态 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/7082471.html
注:详细讲了JAVA的四种引用,通过实例讲解了在什么情况下,每种引用对应的对象会被回收。这才是最重要的。
Java虚拟机16:Metaspace - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/8688203.html
注:介绍lMetaspace相关想基础知识,但我不是很理解,也不知道学习这些有什么用,继续加油吧~~
笔记:
对于堆栈:
- 堆是用来存放对象;
- 而栈是用来执行程序的。
垃圾回收机制:
- 4种引用状态
- 1、强引用
- 2、软引用
- 3、弱引用
- 4、虚引用
- 垃圾回收算法
- 1、标记-清除(Mark-Sweep)算法
- 2、复制(Copying)算法
- 3、标记-整理(Mark-Compact)算法
- 垃圾收集器
- 1、Serial收集器
- 新生代收集器(Client模式下:默认)
- 复制算法
- 单线程
- 2、ParNew收集器(Serial收集器的多线程版本)
- 新生代收集器(Server模式下:首选)
- 复制算法
- 多线程
- 3、Parallel收集器
- 新生代收集器(Server模式下:默认)
- 复制算法
- 多线程
- 目标:达到一个可控制的吞吐量
- 4、Serial Old收集器(Serial收集器的老年代版本)
- 老年代收集器
- 标记-整理算法
- 单线程
- 5、Parallel Old收集器(Parallel收集器的老年代版本)
- 老年代收集器
- 标记-整理算法
- 多线程
- 6、CMS收集器
- 老年代收集器
- 标记-清除算法
- 线程?
- 目标:获取最短回收停顿时间
- 7、G1收集器
- 好像忽略了新生代和老年代...跨时代
收集器分类总结:
Java虚拟机1:什么是Java - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4826691.html
注:初步了解JAVA虚拟机,只是说明介绍,没有太多实际东西。
Java虚拟机2:Java内存区域及对象 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4827590.html
注:初步讲解了堆和栈的含义,以及内存说明。后面讲了对象创建时内存的分配,以及如何对象寻址,比价重要。
Java虚拟机3:常用JVM命令参数 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4830692.html
注:主要讲了常用JVM命令参数的含义。
Java虚拟机4:内存溢出 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4833713.html
注:主要讲了内存溢出:堆溢出、栈溢出,以及方法区和运行时常量池溢出,了解一下。
Java虚拟机5:Java垃圾回收(GC)机制详解 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4836700.html
注:介绍了垃圾回收算法,垃圾收集器,以及垃圾收集的实例代码讲解,还有如何观看GC日志。如果深入学习,那么这一块很需要好好看看。
Java虚拟机6:内存溢出和内存泄露、并行和并发、Minor GC和Full GC、Client模式和Server模式的区别 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4839245.html
注:主要介绍概念,标题中的。其他主要讲解Client模式和Server模式的区别:主要是不同模式下使用不同的JIT编译器。
Java虚拟机7:内存分配原则 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4841177.html
注:主要讲了内存分配原则,即新建对象优先分配在新生代还是老年代,如果新生代GC或者老年代FGC,内存是如何转移的,以及一些内存分配原则说明。
Java虚拟机8:虚拟机性能监控与故障处理工具 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4842483.html
注:主要讲了查询虚拟机一些基本信息的常用命令,有了这些命令我们才能获取到虚拟机具体的状态,才能发现问题,然后解决问题。
另外,简单提了一些其他工具:JDK自带的,以及一些付费工具等。后续实际分析时可以参考。
Java虚拟机9:Java类加载机制 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4844915.html
注:类使用的7个阶段:加载(Loading)、验证(Verification)、准备(Preparation)、解析(Resolution)、初始化(Initiallization)、使用(Using)和卸载(Unloading)这7个阶段。
每个阶段分别做了一些重要说明。不是很理解,不过可以先记着,后续需要再细看。
Java虚拟机10:类加载器 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4845144.html
注:主要介绍了类加载器,主要就是如何对类加载,是第九篇文章里加载部分的比较详细的讲解。
不做笔记,后续有需要直接看原文。
Java虚拟机11:运行期优化 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4857820.html
注:这篇文章主要详细讲了运行期优化,即JIT即时编译相关,主要是如何确定需要进行即时编译:方法调用计数器和回边计数器;另外还有编译过程中的优化技术:公共子表达式消除,数组范围检查消除和方法内联以及逃逸分析。可以简单理解一下。
Java虚拟机12:Java内存模型 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4859107.html
注:这一章主要是讲了多线程相关,因为内存模型对多线程影响很大,主要想说明了两个内存:主内存和工作内存。以及两种内存之间的交互(原子性操作),以及一些交互规则。
最后,顺带说了volatile关键字的作用和synchronized关键字的作用。
还有先行发生happens-before原则:一共8个。线程之间的安全问题可以通过这八个原则来进行判断。
Java虚拟机13:互斥同步、锁优化及synchronized和volatile - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4978876.html
注:互斥是因,同步是果;互斥是方法,同步是目的。
另外主要从编译的字节码层次讲了:synchronized的实现和volatile的实现。
Java虚拟机14:Java对象大小、对象内存布局及锁状态变化 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/6928133.html
注:一个对象占多少字节,除了基本数据类型的字节数,还有不同操作系统保存对象元数据的内存。这些内容加起来,才是一个对象占用的全部字节。
还讲了JAVA的四种锁的状态:无锁态、偏向锁、轻量级锁和重量级锁。详细介绍了每种锁的优点,以及在什么情况下,锁会由次一级升级为高一级的锁。
Java虚拟机15:再谈四种引用状态 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/7082471.html
注:详细讲了JAVA的四种引用,通过实例讲解了在什么情况下,每种引用对应的对象会被回收。这才是最重要的。
Java虚拟机16:Metaspace - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/8688203.html
注:介绍lMetaspace相关想基础知识,但我不是很理解,也不知道学习这些有什么用,继续加油吧~~
对于堆栈:
- 堆是用来存放对象;
- 而栈是用来执行程序的。
垃圾回收机制:
- 4种引用状态
- 1、强引用
- 2、软引用
- 3、弱引用
- 4、虚引用
- 垃圾回收算法
- 1、标记-清除(Mark-Sweep)算法
- 2、复制(Copying)算法
- 3、标记-整理(Mark-Compact)算法
- 垃圾收集器
- 1、Serial收集器
- 新生代收集器(Client模式下:默认)
- 复制算法
- 单线程
- 2、ParNew收集器(Serial收集器的多线程版本)
- 新生代收集器(Server模式下:首选)
- 复制算法
- 多线程
- 3、Parallel收集器
- 新生代收集器(Server模式下:默认)
- 复制算法
- 多线程
- 目标:达到一个可控制的吞吐量
- 4、Serial Old收集器(Serial收集器的老年代版本)
- 老年代收集器
- 标记-整理算法
- 单线程
- 5、Parallel Old收集器(Parallel收集器的老年代版本)
- 老年代收集器
- 标记-整理算法
- 多线程
- 6、CMS收集器
- 老年代收集器
- 标记-清除算法
- 线程?
- 目标:获取最短回收停顿时间
- 7、G1收集器
- 好像忽略了新生代和老年代...跨时代
收集器分类总结:
主要是:Serial和Parallel
Serial包含3个:新生代的单线程版本(Serial收集器)和多线程版本(ParNew收集器),以及老年代的单线程版本(Serial Old收集器)
Parallel包含2个:新生代的多线程版本(Parallel收集器)和老年代的多线程版本(Parallel Old收集器)
还有两个其他:CMS收集器和G1收集器
垃圾收集器组合:
Serial+Serial Old:Client模式下的默认垃圾收集器组合;
Parallel+Serial Old:Server模式下的默认垃圾收集器组合;
Java内存模型
- 8个原子操作:
- 主内存:
- lock(锁定)
- unlock(解锁)
- read(读取)
- write(写入)
- 工作内存:
- load(载入):与主内存交互
- use(使用)
- assign(赋值)
- store(存储):与主内存交互
- volatile型变量的特殊规则
- volatile型变量的特性:
- 1、保证此变量对所有线程的"可见性"。
- 所谓"可见性"是指当一条线程修改了这个变量的值,新值对于其它线程来说都是可以立即得知的。
- volatile只保证了可见性,并不保证基于volatile变量的运算在并罚下是安全的
- 2、使用volatile变量的第二个语义是禁止指令重排序优化。
- volatile型变量的规则:
- 1、在工作内存中,每次使用某个变量的时候都必须线从主内存刷新最新的值,用于保证能看见其他线程对该变量所做的修改之后的值
- 2、在工作内存中,每次修改完某个变量后都必须立刻同步回主内存中,用于保证其他线程能够看见自己对该变量所做的修改
- 3、volatile修饰的变量不会被指令重排序优化,保证代码的执行顺序与程序顺序相同