Learn && Live
虚度年华浮萍于世,勤学善思至死不渝
Hey,欢迎阅读Connor学JVM系列,这个系列记录了我的JVM基础知识学习、复盘过程,欢迎各位大佬阅读斧正!原创不易,转载请注明出处:http://t.csdn.cn/9XQaO,话不多说我们马上开始!
分为强引用(Strongly Reference)、软引用(Soft Reference)、弱引用(Weak Reference)、虚引用(Phantom Reference)
(1)强引用指创建一个对象并赋给一个引用变量,如Object obj = new Object()
(2)无论任何情况下,只要强引用关系还存在,垃圾收集器就永远不会回收掉被引用的对象,即使是抛出了OOM错误。
(3)如果想中断强引用和某对象之间的关联,可以显式地将引用赋值为null
(1)当内存空间充足时,垃圾回收器不会回收具有软引用的对象
(2)当内存空间不足时,会把这些对象列入回收范围内并进行回收,如果第二次回收后内存仍不足,才会抛出OOM错误
(3)软引用可用来实现内存敏感的高速缓存,如网页缓存、图片缓存等,能够防止内存泄露,增强程序的健壮性
(4)若一个SoftReference保存了对一个对象的软引用后,在这个对象被回收前,可以通过SoftReference类的get()方法返回这个对象的强引用,但如果这个对象已经被回收,就只能获取到null了
Object obj = new Object();
SoftReference soft = new SoftReference(obj);
Object other = (MyObject) soft.get();
(5)可以使用ReferenceQueue清除失去了软引用对象的SoftReference。在创建SoftReference对象的时候可以使用了ReferenceQueue对象作为参数的构造方法,当SoftReference引用的对象obj被回收后,这个SoftReference对象会被加入ReferenceQueue中,我们可以调用poll()方法来检查哪个SoftReference引用的对象被回收了,并消除这些失效的SoftReference对象
Object obj = new Object();
ReferenceQueue queue = new ReferenceQueue();
SoftReference soft = new SoftReference(obj, queue);
当垃圾回收器开始工作,无论当前内存是否足够,都会回收掉只被弱引用关联的对象。注意这里的只,如果存在强引用或软引用同时与之关联,则进行垃圾回收时不会回收该对象。在java中,用java.lang.ref.WeakReference类来表示。弱引用同样也可以结合ReferenceQueue使用
(1)也称为“幽灵引用”或“幻影引用”
(2)如果一个对象与虚引用关联,则跟没有引用与之关联一样,在任何时候都可能被垃圾回收器回收
(3)虚引用必须和引用队列关联使用,当垃圾回收器准备回收一个对象时,如果发现它还有虚引用,就会把这个虚引用加入到与之 关联的引用队列中。程序可以通过判断引用队列中是否已经加入了虚引用,来了解被引用的对象是否将要被垃圾回收。如果程序发现某个虚引用已经被加入到引用队列,那么就可以在所引用的对象的内存被回收之前采取必要的行动。
假如有一个应用需要读取大量的本地图片,如果每次读取图片都从硬盘读取,则会严重影响性能,但是如果全部加载到内存当中,又有可能造成内存溢出,此时使用软引用可以解决这个问题
设计思路是:用一个HashMap来保存图片的路径 和 相应图片对象关联的软引用之间的映射关系,在内存不足时,JVM会自动回收这些缓存图片对象所占用的空间,从而有效地避免了OOM的问题。在Android开发中对于大量图片下载会经常用到