package reference;
import java.lang.ref.SoftReference;
import java.lang.ref.WeakReference;
/*
* @author: wjf
* @version: 2016年3月30日 下午3:55:53
*/
public class TestReference {
public static void main(String[] args){
/*
* java 中 四中引用 方法强引用,软引用,弱引用,虚引用
* 强引用,大多数适用场景,只有有强引用存在就不会被GC 回收,
* 软引用,内存不足时,会被gc 回收
* 弱引用,gc 执行时,就会被回收
* 虚引用, 虚引用和前面的软引用、弱引用不同,它并不影响对象的生命周期。在java中用java.lang.ref.PhantomReference类表示。如果一个对象与虚引用关联,则跟没有引用与之关联一样,在任何时候都可能被垃圾回收器回收。
要注意的是,虚引用必须和引用队列关联使用,当垃圾回收器准备回收一个对象时,如果发现它还有虚引用,就会把这个虚引用加入到与之 关联的引用队列中。程序可以通过判断引用队列中是否已经加入了虚引用,来了解被引用的对象是否将要被垃圾回收。如果程序发现某个虚引用已经被加入到引用队列,那么就可以在所引用的对象的内存被回收之前采取必要的行动。
*
* 适用 软引用和弱引用可以有效结果OOM 问题,
* 如下场景:
* 当需要从本地读取大量图片时,如果从本地硬盘读取,则严重影响性能,如果都加载到内存中,则可能发生内存溢出的危险,
* 适用 软引用可以有效解决问题。当内存不足时,gc 自动清除缓存的图片对象。
*/
// private Map<String, SoftReference<Bitmap>> imageCache = new HashMap<String, SoftReference<Bitmap>>();
// <br>....
// public void addBitmapToCache(String path) {
//
// // 强引用的Bitmap对象
//
// Bitmap bitmap = BitmapFactory.decodeFile(path);
//
// // 软引用的Bitmap对象
//
// SoftReference<Bitmap> softBitmap = new SoftReference<Bitmap>(bitmap);
//
// // 添加该对象到Map中使其缓存
//
// imageCache.put(path, softBitmap);
//
// }
//
// public Bitmap getBitmapByPath(String path) {
//
// // 从缓存中取软引用的Bitmap对象
//
// SoftReference<Bitmap> softBitmap = imageCache.get(path);
//
// // 判断是否存在软引用
//
// if (softBitmap == null) {
//
// return null;
//
// }
//
// // 取出Bitmap对象,如果由于内存不足Bitmap被回收,将取得空
//
// Bitmap bitmap = softBitmap.get();
//
// return bitmap;
// }
SoftReference<String> s=new SoftReference<String>(new String("wangjianfei"));
WeakReference<String> ws=new WeakReference<String>(new String("csm"));
System.gc();
System.out.println(s.get());
System.out.println(ws.get());
}
}