java中强引用、软引用、弱应用、虚引用

        在一次面试经历中,被问到java中的四种引用类型,平时工作中没有去深入的学习,只是在一次安卓开发过程中为了解决内存泄漏问题,使用到了弱引用。现在对java中的四种引用类型做一下简单的介绍。从JDK1.2开始,对象的引用被分为了四个级别:强引用、软引用、弱引用、虚引用,从而使程序更加灵活的控制对象的生命周期。

强引用:在我们平时编程中,用的最多的其实就是强引用,比如

User user = new User()


,则这个user就是一个强引用,如果一个对象具有强引用,那Java虚拟机宁愿抛出out of memory也不会对这个对象进行回收。


软引用:如果一个对象只具有软引用,如果java虚拟机内存空间足够,垃圾回收器就不会回收它,但当内存空间不足时,就会回收这些对象的内存。只要垃圾回收器没有回收它,该对象就可以被程序使用。软引用可用来实现内存敏感的高速缓存。sr就是一个软引用。

SoftReference<User> sr = new SoftReference<User>(new User());




弱引用:如果一个对象只具有弱引用,则不管java虚拟机内存是否足够,在垃圾回收器扫描它所管辖的范围的过程,一旦gc发现对象为weakReference可达,就会把它放到ReferenceQueue,等待下次gc回收它所以在使用弱引用的时候,注意通过wr.get()判断对象是否已为null。

WeakReference<User> wr = new WeakReference<User>(new User());




虚引用:“虚引用”顾名思义,就是形同虚设,与其他几种引用都不同,虚引用并不会决定对象的生命周期。如果一个对象 仅持有虚引用,那么它就和没有任何引用一样,在任何时候都可能被垃圾回收。 虚引用主要用来跟踪对象被垃圾回收的活动。虚引用与软引用和弱引用的一个区别在于:虚引用必须和引用队列 (ReferenceQueue)联合使用。当垃圾回收器准备回收一个对象时,如果发现它还有虚引用,就会在回收对象的内存之前,把这个虚引用加入到与之 关联的引用队列中。程序可以通过判断引用队列中是否已经加入了虚引用,来了解被引用的对象是否将要被垃圾回收。程序如果发现某个虚引用已经被加入到引用队 列,那么就可以在所引用的对象的内存被回收之前采取必要的行动。




  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java,垃圾回收机制会自动回收不再使用的对象,而引用可以影响垃圾回收机制的行为。Java有四种类型的引用强引用引用引用和幻象引用引用),它们的主要区别在于垃圾回收对它们的处理方式不同。 1. 强引用(Strong Reference):是最常见的引用类型,如果一个对象具有强引用,那么垃圾回收器就不会回收它,即使内存不足,JVM也不会回收它。例如: ``` Object obj = new Object(); // obj是一个强引用 ``` 2. 引用(Soft Reference):是一种相对强引用化了一些的引用,可以让对象豁免一些垃圾收集。只有当内存不足时,JVM才会回收引用指向的对象,因此,引用非常适合缓存实现。例如: ``` Object obj = new Object(); SoftReference<Object> softRef = new SoftReference<>(obj); // softRef是一个引用 ``` 3. 引用(Weak Reference):是比引用化了一些的引用,只有当垃圾回收器扫描到引用指向的对象时,才会回收该对象。引用非常适合解决内存泄漏问题。例如: ``` Object obj = new Object(); WeakReference<Object> weakRef = new WeakReference<>(obj); // weakRef是一个引用 ``` 4. 幻象引用(Phantom Reference):也称为引用,是最的一种引用。一个对象是否有引用与其生命周期无关,也无法通过引用来获得对象的实例,只有当垃圾回收器回收了一个对象时,才会将其关联的引用加入到引用队列。例如: ``` Object obj = new Object(); ReferenceQueue<Object> queue = new ReferenceQueue<>(); PhantomReference<Object> phantomRef = new PhantomReference<>(obj, queue); // phantomRef是一个幻象引用 ``` 可以通过以下代码示例来更好地理解四种引用类型的区别: ``` public class ReferenceDemo { public static void main(String[] args) { Object obj = new Object(); SoftReference<Object> softRef = new SoftReference<>(obj); // 引用 WeakReference<Object> weakRef = new WeakReference<>(obj); // 引用 ReferenceQueue<Object> queue = new ReferenceQueue<>(); PhantomReference<Object> phantomRef = new PhantomReference<>(obj, queue); // 幻象引用 System.out.println("强引用对象:" + obj); System.out.println("引用对象:" + softRef.get()); System.out.println("引用对象:" + weakRef.get()); System.out.println("幻象引用对象:" + phantomRef.get()); System.out.println("引用队列:" + queue.poll()); obj = null; System.gc(); System.out.println("强引用对象:" + obj); System.out.println("引用对象:" + softRef.get()); System.out.println("引用对象:" + weakRef.get()); System.out.println("幻象引用对象:" + phantomRef.get()); System.out.println("引用队列:" + queue.poll()); } } ``` 输出结果如下: ``` 强引用对象:java.lang.Object@1b6d3586 引用对象:java.lang.Object@1b6d3586 引用对象:java.lang.Object@1b6d3586 幻象引用对象:null 引用队列:null 强引用对象:null 引用对象:java.lang.Object@1b6d3586 引用对象:null 幻象引用对象:null 引用队列:java.lang.ref.PhantomReference@4554617c ``` 可以看到,在垃圾回收后,强引用对象为null,引用对象和幻象引用对象都没有被回收,而引用对象已经被回收了。同时,幻象引用的关联对象被加入到了引用队列

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值