GC
$TODO$
一个对象的生命周期
一个对象的生命周期从它被创建开始,此时虚拟机会给它置一个内部标识finalizable,当 GC 到达某一个安全点并检验该对象不可达,即无引用指向它时,该对象会被放入一个 finalize queue(F queue),虚拟机将会执行其 finalize() 方法,并将 finalizable 标识清空,然后销毁该对象,其中 finalize() 方法的执行顺序是不稳定的,而且只能被执行一次
也就是说,如果在 finalize() 中采取某些方法,将有可能将对象从死亡边缘挽救回来,如果令一个引用指向 this,该对象很可能会在这次 GC 中复活,但只有一次
通常来说,不建议重写此方法
引用分类
Java 中,引用可以分为四种,下面我们简单地概括一下,其中,内存溢出之前指百分之九十八的 GC 回收了百分之二的内存
|引用|回收策略
|:-: |:-: ||强引用|无引用指向时||软引用|内存溢出之前||弱引用|无比弱引用更强的引用指向时|虚引用并没在上表,因为我也不清楚它地用途所在
以下为摘录自 《深入理解Java虚拟机》 中关于引用的内容:
在jdk1.2之后,Java对引用的概念进行了扩充,将引用分为强引用(Strong Reference)、软引用(Soft Reference)、弱引用(Weak Reference)、虚引用(Phantom Reference)四种:
强引用就是指在程序代码之中普遍存在的,类似Object obj = new Object()这类的引用,只要强引用还存在,垃圾收集器永远不会回收掉被引用的对象
软引用是用来描述一些还有用但并非必需的对象。对于软引用关联着的对象,在系统将要发生 内存溢出异常之前,将会把这些对象列进回收范围之中进行第二次回收。在jdk1.2之后提供了 SoftReference
类来实现软引用
弱引用也是用来描述非必需对象的,但是它的强度比软引用更弱一些,被弱引用关联的对象只能生存到下一次垃圾收集发送之前。当垃圾收集器工作时,无论内存是否足够,都会回收掉 只被弱引用关联的对象。在jdk1.2之后提供了 WeakReference 类来实现弱引用
虚引用也称为幽灵引用或者幻影引用,它是最弱的一种引用关系。一个对象是否有虚引用的存在,完全不会对其生存时间构成影响,也无法通过虚引用来取得一个对象实例。为一个对象设置虚引用关联的唯一目的就是能在这个对象被垃圾收集器回收时收到一个系统通知。在jdk1.2之后提供了 PhantomReference 类来实现虚引用
Reference
$TODO$
ReferenceQueue
$TODO$
参考
1. 《深入理解Java虚拟机》