1.强引用( Strong Reference )


➢最普遍的引用:

      代码中的object和str都是强引用:

Object object = new Object();
String str = "hello";

➢抛出OutOfMemoryError终止程序也不会回收具有强引用的对象
➢通过将对象设置为null来弱化引用,使其被回收

 

2.软引用( Soft Reference )


➢对象处在有用但非必须的状态
➢只有当内存空间不足时, GC会回收该引用的对象的内存
➢可以用来实现高速缓存(作用)--
比如网页缓存、图片缓存

      softRef就是软引用

 软引用还可以和一个引用队列(ReferenceQueue)联合使用,如果软引用所引用的对象被JVM回收,这个软引用就会被加入到与之关联的引用队列中。

public class Main {
    public static void main(String[] args) {
        SoftReference<String> sr = new SoftReference<String>(new String("hello"));
          
        System.out.println(sr.get());
        System.gc();                //通知JVM的gc进行垃圾回收
        System.out.println(sr.get());
    }
}

3.弱引用( Weak Reference )


➢非必须的对象,比软引用更弱一-些
➢GC时会被回
➢被回收的概率也不大,因为GC线程优先级比较低
➢适用于引用偶尔被使用且不影响垃圾收集的对象

String str=new String( original: "abc");
WeakReference<String> abcWeakRef = new WeakReference<String>(str);

4.虚引用( PhantomReference )


➢不会决定对象的生命周期
➢任何时候都可能被垃圾收集器回收
➢跟踪对象被垃圾收集器回收的活动,起哨兵作用

➢必须和引用队列ReferenceQueue联合使用

    当垃圾回收器准备回收一个对象时,如果发现它还有虚引用,就会把这个虚引用加入到与之 关联的引用队列中。程序可以通过判断引用队列中是否已经加入了虚引用,来了解被引用的对象是否将要被垃圾回收。如果程序发现某个虚引用已经被加入到引用队列,那么就可以在所引用的对象的内存被回收之前采取必要的行动。

String str=new String( original: "abc");
ReferenctQueue queue = new ReferenceQueue();
PhantomReference ref = new PhantomReference(str, queue);

 

 

下面看看类层次结构

 

引用队列( ReferenceQueue )


     ➢无实际存储结构,存储逻辑依赖于内部节点之间的关系来表达

     ➢存储关联的且被GC的软引用,弱引用以及虚引用