1 JVM概念
JVM:Java虚拟机
虚拟机:通过软件模拟的具有完整硬件功能的、运行在一个完全隔离的环境中的完整计算机系统。
JVM是通过软件模拟Java字节码的指令集。
2 垃圾回收器
2.1 判断一个对象已经“死亡”
(1)引用计数法
给对象增加一个引用计数器,每当有一个地方引用它时,计数器就+1;当引用失效时,计数器-1;任何时刻计数器为0的对象不能再使用,即对象已“死”。
缺点:无法解决循环引用问题
(2) 可达性分析算法
从起始点开始向下搜索,搜索走过的路径称为“引用链”,当一个对象到起始点没有任何的引用链相连时,证明此对象不可用。
不可达的对象不是真正的死亡,要判定一个对象真正死亡,条件是:是否有必要执行finalize()方法。
当对象没有覆盖finalize()方法或者finalize()方法已经被JVM调用过,虚拟机将这两种情况视为“没有必要执行”,此时对象真正死亡。
对象逃脱死亡:重新与引用链上的任何一个对象建立起关联关系即可。
2.2 回收方法区
方法区的垃圾回收主要收集两部分内容:废弃常量和无用的类。
例:字符串的常量池中一个常量没有被任何一个String对象引用,如果此时发生GC并且有必要,这个常量会被系统清理出常量池。
判断一个类是否是无用类:
- 该类所有实例都已经被回收
- 加载该类的ClassLoader已经被回收
- 该类对应的class对象没有在任何其他地方被引用,无法在任何地方通过反射访问该类的方法
2.3 垃圾回收算法
2.3.1 标记-清除算法
先标记所有需要回收的对象,标记完成后统一回收。
2.3.2 复制算法(新生代回收算法)
- 将内存按容量划分为大小相等的两块,每次只使用其中的一块
- 将活着的复制到另一块,清除已使用过的内存区域
2.3.3 标记-整理算法(老年代回收算法)
- 将所有存活对象都向一端移动
- 清理掉一端边界以外的内存
2.3.4 分代收集算法
- 在新生代中,每次垃圾回收都有大批对象死去,只有少量存活,采用复制算法
- 在老年代中,对象存活率较高,没有额外空间对它进行分配担保,采取“标记-清除”或“标记-整理”算法