强引用
我们使用的大部分的引用都是强引用,这是使用最普遍的引用。如果一个对象具有强引用,当内存空间不足,Java虚拟机宁愿抛出OutOfMemoryError错误,使程序异常终止,也不会靠随意回收具有强引用的对象来解决内存不足问题
public static void main(String[] args) {
Object strong = new Object();
Object obj = strong;
strong = null;
System.gc();
System.out.println(obj);
}
GC之后:java.lang.Object@65ab7765
软引用
1.当内存不足,发生OOM的时候就会被回收
2.把软引用设置为null,会被回收
public static void main(String[] args) {
Object obj = new Object();
SoftReference soft = new SoftReference(obj);
obj = null; // 不会被回收
System.out.println(soft.get());
}
java.lang.Object@65ab7765
public static void main(String[] args) {
Object obj = new Object();
SoftReference soft = new SoftReference(obj);
soft = null; // 会被回收
System.out.println(soft.get());
}
Exception in thread "main" java.lang.NullPointerException
at com.xufk.basic.StrongRefDemo.main(StrongRefDemo.java:12)
弱引用
只具有弱引用的对象在没有使用之后,执行垃圾回收的时候会被回收
public static void main(String[] args) throws InterruptedException {
Object obj = new Object();
WeakReference weakReference = new WeakReference(obj);
obj = null;
System.gc();
System.out.println(weakReference.get());
}
null
看下面一个变相的问题,猜猜下面这个打印结果是什么?
public static void main(String[] args) throws InterruptedException {
String str = "123";
WeakReference weakReference = new WeakReference(str);
str = null;
System.gc();
System.out.println(weakReference.get());
}
虚引用
"虚引用"顾名思义,就是形同虚设,与其他几种引用都不同,虚引用并不会决定对象的生命周期。如果一个对象仅持有虚引用,那么它就和没有任何引用一样,在任何时候都可能被垃圾回收。
虚引用必须和引用队列(ReferenceQueue)联合使用
public static void main(String[] args) throws InterruptedException {
ReferenceQueue queue = new ReferenceQueue();
Object obj = new Object();
PhantomReference phant = new PhantomReference(obj,queue);
// 会发现这句打印结果为空
System.out.println(phant.get());
obj = null;
System.gc();
// 会发现这句打印结果为空
System.out.println(phant.get());
Thread.sleep(200);
// 会发现这句打印结果为空,表示回收后进入到了队列
System.out.println(queue.poll());
}
本文是综合自己的认识和参考各类资料(书本及网上资料)编写,若有侵权请联系作者,所有内容仅代表个人认知观点,如有错误,欢迎校正; 邮箱:1354518382@qq.com 博客地址:https://blog.csdn.net/qq_35576976/