Java 弱引用
弱引用与软引用的区别在于:只具有弱引用的对象拥有更短暂的生命周期。在垃圾回收器线程扫描它所管辖的内存区域的过程中,一旦发现了只具有弱引用的对象,不管当前内存空间足够与否,都会回收它的内存。不过,由于垃圾回收器是一个优先级很低的线程,因此不一定会很快发现那些只具有弱引用的对象。
相信很多java同学在学习弱引用的时候都看到过这句话,那么不知道大家想过一个问题没有,GC什么时候执行是不可控的,那么我们用弱引用的方式来使用对象肯定也是不可控的,那我们使用weakReference.get()的时候发生了GC怎么办?
先来看一个Demo
public class Demo {
public static void main(String[] args) {
WeakReference<Demo> weakReference = new WeakReference(new Demo());
System.out.println(weakReference.get());
System.gc();
System.out.println(weakReference.get());
}
}
控制台输出
改造一下
public class Demo {
public static void main(String[] args) {
Demo demo = new Demo();
WeakReference<Demo> weakReference = new WeakReference(demo);
System.out.println(weakReference.get());
System.gc();
System.out.println(weakReference.get());
}
}
控制台输出
再次改造
public class Demo {
public static void main(String[] args) {
Demo demo = new Demo();
WeakReference<Demo> weakReference = new WeakReference(demo);
System.out.println(weakReference.get());
System.gc();
System.out.println(weakReference.get());
demo = null;
System.gc();
System.out.println(weakReference.get());
}
}
控制台输出
相信大家心里已经有答案了
总结
Java弱引用GC后,weakReference.get()方法获取的对象是否为null,取决于该对象是否还有其他强引用指向它,如果有那么weakReference.get()不为null。
我们可以利用这一特性判断本该为null的对象是否发生了内存泄漏。