MyObject aRef = new MyObject();
SoftReference aSoftRef=new SoftReference(aRef);
aRef = null;
//如今只有一个软引用指向MyObject的这个对象,
//若是这个对象尚未被回收,能够把他再次变为强引用
if(aSoftRef.get() != null)
MyObject bRef = aSoftRef.get();
//这个时候MyObject这个对象又变成强引用
复制代码
boolean isEnqueued();经过程序或垃圾收集器来告知这个引用对象是否已经入队;java
其中enqueue 和 isEnqueued 这两个方法涉及到引用队列,咱们后面会讲到。这里就先不解释,留个印象就行。缓存
软引用经过SoftReference类实现。软引用的生命周期比强引用短一些。只有当 JVM 认为内存不足时,才会去试图回收软引用指向的对象:即JVM 会确保在抛出 OutOfMemoryError 以前,清理软引用指向的对象。软引用能够和一个引用队列(ReferenceQueue)联合使用,若是软引用所引用的对象被垃圾回收器回收,Java虚拟机就会把这个软引用(注意是引用自己这个对象(就是Reference本身,并非引用所引用的对象)加入到与之关联的引用队列中。后续,咱们能够调用ReferenceQueue的poll()方法来检查是否有它所关心的对象被回收(由于在这个队列里面的引用所指向的对象都被回收了)。若是队列为空,将返回一个null,不然该方法返回队列中前面的一个Reference对象。bash
应用场景:软引用一般用来实现内存敏感的缓存。若是还有空闲内存,就能够暂时保留缓存,当内存不足时清理掉,这样就保证了使用缓存的同时,不会耗尽内存。函数
弱引用经过WeakReference类实现。 弱引用的生命周期比软引用短。在垃圾回收器线程扫描它所管辖的内存区域的过程当中,一旦发现了具备弱引用的对象,无论当前内存空间足够与否,都会回收它的内存。因为垃圾回收器是一个优先级很低的线程,所以不必定会很快回收弱引用的对象。弱引用能够和一个引用队列(ReferenceQueue)联合使用,若是弱引用所引用的对象被垃圾回收,Java虚拟机就会把这个弱引用加入到与之关联的引用队列中(和引用队列一块儿使用同上面的软引用)。post
应用场景:弱应用一样可用于内存敏感的缓存。spa
幻象引用也叫虚引用,经过PhantomReference类来实现。没法经过虚引用访问对象的任何属性或函数。幻象引用仅仅是提供了一种确保对象被 finalize 之后,作某些事情的机制。若是一个对象仅持有虚引用,那么它就和没有任何引用同样,在任什么时候候均可能被垃圾回收器回收。虚引用必须和引用队列 (ReferenceQueue)联合使用。当垃圾回收器准备回收一个对象时,若是发现它还有虚引用,就会在回收对象的内存以前,把这个虚引用加入到与之关联的引用队列中。程序能够经过判断引用队列中是否已经加入了虚引用,来了解被引用的对象是否将要被垃圾回收。若是程序发现某个虚引用已经被加入到引用队列,那么就能够在所引用的对象的内存被回收以前采起一些程序行动(和引用队列一块儿使用同上面软引用跟弱引用)。线程
应用场景:可用来跟踪对象被垃圾回收器回收的活动,当一个虚引用关联的对象被垃圾收集器回收以前会收到一条系统通知3d
ReferenceQueue queue = new ReferenceQueue();
SoftReference ref=new SoftReference(aMyObject,queue);
复制代码
SoftReference ref = null;
while ((ref = (EmployeeRef) q.poll()) != null) {
// 清除ref
}
复制代码
在强引用、软引用、弱引用、幻象引用的介绍我引用了一些其余博客下的评论,因为很差贴连接就只能声明一下吧。code