1、引用强度排序html
强引用>软引用>弱引用>虚引用缓存
2、强引用:htm
1. 正常建立的对象,只要引用存在,永远不会被GC回收,即便OOM对象
Object obj = new Object();blog
2. 若是要中断强引用和某个对象的关联,为其赋值null,这样GC就会在合适的时候回收对象排序
3. Vector类的clear()方法就是经过赋值null进行清除队列
3、软引用内存
1. 内存溢出以前进行回收,GC时内存不足时回收,若是内存足够就不回收get
2. 使用场景:在内存足够的状况下进行缓存,提高速度,内存不足时JVM自动回收监控
Object obj = new Object();
SoftReference<Object> sf = new SoftReference<Object>(obj);
sf.get();//有时候会返回null
3. 能够和引用队列ReferenceQueue联合使用,若是软引用所引用的对象被JVM回收,这个软引用就会被加入到与之关联的引用队列中
4、弱引用
1. 每次GC时回收,不管内存是否足够
2. 使用场景:a. ThreadLocalMap防止内存泄漏 b. 监控对象是否将要被回收
Object obj = new Object();
WeakReference<Object> wf = new WeakReference<Object>(obj);
wf.get();//有时候会返回null
wf.isEnQueued();//返回是否被垃圾回收器标记为即将回收的垃圾
System.gc(); //通知JVM的gc进行垃圾回收,但JVM不必定会马上执行
wf.get();//此时会返回null
3. 弱引用能够和一个引用队列(ReferenceQueue)联合使用,若是弱引用所引用的对象被JVM回收,这个软引用就会被加入到与之关联的引用队列中
5、虚引用
1. 每次垃圾回收时都会被回收,主要用于监测对象是否已经从内存中删除
2. 虚引用必须和引用队列关联使用, 当垃圾回收器准备回收一个对象时,若是发现它还有虚引用,就会把这个虚引用加入到与之 关联的引用队列中
3. 程序能够经过判断引用队列中是否已经加入了虚引用,来了解被引用的对象是否将要被垃圾回收。若是程序发现某个虚引用已经被加入到引用队列,那么就能够在所引用的对象的内存被回收以前采起必要的行动
Object obj = new Object();
PhantomReference<Object> pf = new PhantomReference<Object>(obj);
obj=null;
pf.get();//永远返回null
pf.isEnQueued();//返回是否从内存中已经删除
参考: