3)不可达状态:当对象的所有关联都被切断,且系统调用finalize()方法进行资源清理后依旧没有使该对象变为可达状态,则这个对象将性失去引用并且变成不可达状态,系统才会真正的去回收该对象所占用的资源。

  上述三种状态的转换图如下:

  2、Java对对象的4种引用

  1)强引用:创建一个对象并把这个对象直接赋给一个变量,eg:Person person = new Person(“sunny”); 不管系统资源有么的紧张,强引用的对象都不会被回收,即使他以后不会再用到。

  2)软引用:通过SoftReference类实现,eg : SoftReference<Person> p = new SoftReference<Person>(new Person(“Rain”));,内存非常紧张的时候会被回收,其他时候不会被回收,所以在使用之前要判断是否为null从而判断他是否已经被回收了。

  3)弱引用:通过WeakReference类实现,eg : WeakReference<Person> p = new WeakReference<Person>(new Person(“Rain”));不管内存是否足够,系统垃圾回收时必定会回收。

  4)虚引用:不能单独使用,主要是用于追踪对象被垃圾回收的状态。通过PhantomReference类和引用队列ReferenceQueue类联合使用实现,eg:
package test; 
   
 import java.lang.ref.PhantomReference; 
 import java.lang.ref.ReferenceQueue; 
   
   
 public class Test{ 
   
     public static void main(String[] args) { 
         //创建一个对象 
         Person person = new Person("Sunny");     
         //创建一个引用队列     
         ReferenceQueue<Person> rq = new ReferenceQueue<Person>(); 
         //创建一个虚引用,让此虚引用引用到person对象 
         PhantomReference<Person> pr = new PhantomReference<Person>(person, rq); 
         //切断person引用变量和对象的引用 
         person = null; 
         //试图取出虚引用所引用的对象 
         //发现程序并不能通过虚引用访问被引用对象,所以此处输出为null 
         System.out.println(pr.get()); 
         //强制垃圾回收 
         System.gc(); 
         System.runFinalization(); 
         //因为一旦虚引用中的对象被回收后,该虚引用会进入引用队列中 
         //所以用队列中先进入队列中引用与pr进行比较,输出true 
         System.out.println(rq.poll() == pr); 
     } 
 }

  运行结果: