Java的内存回收机制
作者:网络转载 发布时间:[ 2013/4/3 10:24:08 ] 推荐标签:
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);
}
}
运行结果:


sales@spasvo.com