java 四种引用类型

本文详细介绍了Java中的四种引用类型:强引用、软引用、弱引用和虚引用,包括它们的目的、作用以及触发垃圾收集的条件。通过具体代码示例展示了如何使用这些引用类型,并阐述了它们在内存管理、缓存技术和对象生命周期控制中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在Java中有四种引用类型,他们是:强引用(Strong Reference),软引用(Soft Reference),弱引用(Weak Reference) 和 虚引用(Phantom Reference)。

一.四种引用类型的解释:

  • JVM会持有一般对象直到他们不再是可触及的状态。换句话说,当没有任何有效引用指向他们的时候会被垃圾回收,无效引用不会被计算在内。
  • 软引用指向的对象会在不存在任何指向他们的引用并且内存空间不足情况下被垃圾收集。大多数情况下被用来实现内存敏感的缓存。没有GC的时间限制,会在OOM发生之前清理完毕。
  • 弱引用指向的对象会在没有任何引用指向他们的时候立即被垃圾收集。如果一个对象只有弱引用的话,那么这个对象是不可触及的。这些对象会在任何时候被垃圾收集并且会在下一个GC周期里被丢弃。
  • 虚引用指向的是已经执行finalize方法,但是还没有回收内存的对象。
二.四种引用类型的比较:

类型目的作用触发GC条件实现类
强引用普通引用类型,只要对象的引用是强引用,他们就不会被垃圾收集普通引用任何对象如果不是强引用都可以被垃圾收集默认类型
软引用在内存足够的时候,对象不会被垃圾收集为了保证即使对象没有任何引用指向它的时候也不会被垃圾收集,防止有引用再次指向这个对象在第一次GC后,JVM需要回收更多的空间java.lang.ref.SoftReference
弱引用在对象可触及的状态下不会被垃圾收集如果对象不再被引用会被自动回收GC后对象只有弱引用java.lang.ref.WeakReference
java.util.WeakHashMap
虚引用让你可以清理已经执行finalize方法,但是还没有回收内存的对象特殊清理finalize方法执行之后java.lang.ref.PhantomReference

相关代码及概念如下所述:

    Java有四种引用类型,strongreference,softreference,weakreference,phantomreference。这四种引用的强度按照上面的顺序依次减弱,下面通过几个例子简单了解一下这四种引用类型。 

        StrongReference 

        这个不用多讲了,这是java默认的引用类型,如果不特意使用java.lang.ref下的类,那么程序中的所有引用都是强引用。有强引用存在的对象永远都不会被gc收集,所以在内存不够用时,JVM宁愿抛出OutOfMemoryError这样的错误,也不愿意将强引用对象进行回收。 

        SoftReference 

        软引用不会保证对象一定不会被回收,只能最大可能保证。如果内存有剩余,那么软引用对象不会被回收,如果内存不足,那么gc会回收软引用对象。所以这种特性可以用来实现缓存技术。软引用要用java.lang.ref.SoftReference来实现。 

Java代码   收藏代码
  1. public class SoftTest{  
  2.     public static void main(String[] args) {  
  3.         Object ref = new Object();//ref是Object对象的强引用  
  4.   
  5.         //将一个软引用指向对象,此时Object对象有两个引用  
  6.         SoftReference<Object> sf = new SoftReference<Object>(ref);  
  7.   
  8.         ref = null;//去除对象的强引用  
  9.         System.gc();//gc只有在内存不足是才会回收软引用对象  
  10.     }  
  11. }  


         WeakReference  

        除了通过java.lang.ref.WeakReference来使用弱引用,WeakHashMap同样也利用了弱引用。 
        和软引用不同的是,弱引用一定会被gc回收,不管内存是否不足。 
Java代码   收藏代码
  1. public class WeakTest{  
  2.     public static void main(String[] args) {  
  3.         Object ref = new Object();//ref是Object对象的强引用  
  4.   
  5.         //将一个弱引用指向对象,此时Object对象有两个引用  
  6.         WeakReference<Object> wf = new WeakReference<Object>(ref);  
  7.   
  8.         ref = null;//去除对象的强引用  
  9.         System.gc();//gc对弱引用对象进行回收  
  10.     }  
  11. }  


         PhantomReference  

        幽灵引用,也叫虚引用。java.lang.ref.PhantomReference类中只有一个方法get(),而且几乎没有实现,只是返回null。而且这个类只有一个构造器(软引用和弱引用均有两个构造器): 
Java代码   收藏代码
  1. public PhantomReference(T referent, ReferenceQueue<? super T> q) {  
  2.     super(referent, q);  
  3.     }  

        也就是说,幽灵引用只能与ReferenceQueue(后面会提到这个类)一起使用。如果一个对象仅有幽灵引用,那么它就像没有任何引用一样,在任何时候都可能被gc回收。幽灵引用主要用来跟踪对象被垃圾回收的活动。 
Java代码   收藏代码
  1. public class PhantomTest{  
  2.     public static void main(String[] args) {  
  3.         Object ref = new Object();//ref是Object对象的强引用  
  4.   
  5.         //将一个幽灵引用指向对象,PhantomReference必须与ReferenceQueue一同使用  
  6.         PhantomReference<Object> pf = new PhantomReference<Object>(ref, new ReferenceQueue<Object>());  
  7.   
  8.         System.out.println(pf.get());  
  9.     }  
  10. }  


         ReferenceQueue  

        如果一个对象只有软引用、弱引用或者幽灵引用,gc在回收对象时,JVM会自动将其引用放入一个ReferenceQueue中。WeakHashMap就是利用了ReferenceQueue来实现清除没有强引用Entry的。将上面的弱引用例子稍微改一下: 
Java代码   收藏代码
  1. public class ReferenceQueueTest{  
  2.     public static void main(String[] args) {  
  3.         Object ref = new Object();//ref是Object对象的强引用  
  4.         System.out.println(ref);  
  5.           
  6.         ReferenceQueue<Object> rq=new ReferenceQueue<Object>();//有强引用的ReferenceQueue  
  7.   
  8.         WeakReference<Object> sf = new WeakReference<Object>(ref,rq);//构造弱引用时传入ReferenceQueue  
  9.         System.out.println(sf);  
  10.   
  11.         ref = null;//去除对象的强引用,在这里加个断点,进行调试  
  12.         System.gc();//gc对弱引用对象进行回收  
  13.         System.out.println(rq.poll());  
  14.     }  
  15. }  

        注意,运行这个程序需要用debug模式进行调试,在上面说明的地方加个断点。如果直接运行,结果很可能只是个null,用debug调试的话会看到输出的是弱引用的地址。程序输出的sf结果和rq.poll()结果相同。


转载自:http://blog.youkuaiyun.com/smcwwh/article/details/7168233

           http://paddy-w.iteye.com/blog/986796

详情参考:http://www.cnblogs.com/skywang12345/p/3154474.html

参考:http://blog.youkuaiyun.com/coding_or_coded/article/details/6603549

使用软引用构建敏感数据的缓存:http://www.cnblogs.com/sense7/archive/2012/07/31/2616799.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值