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);
}
}
运行结果:
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11