Android性能优化之巧用软引用与弱引用优化内存使用

来源:互联网 发布:靠谱泰国代购淘宝 知乎 编辑:程序博客网 时间:2024/06/02 06:24
1.StrongReference(强引用)
   强引用是我们最最常见的一种,一般我们在代码中直接通过new出来的对象等,都是强引用,强引用只要存在没有被销毁,内存就不会被系统回收。我们以生成Bitmap为例如下:
Bitmap imageBitmap = readBitmapFromResource(getResources(), R.mipmap.bg_post_activity_5);
  生成Bitmap代码:
public Bitmap readBitmapFromResource(Resources resources, int resourcesId) { BitmapFactory.Options options = new BitmapFactory.Options(); return BitmapFactory.decodeResource(resources, resourcesId, options); }
2.SoftReference(软引用)
  软引用是用来描述一些有用但并不是必需的对象,在内存严重不足的情况下会被系统回收,如果该对象可能会经常使用的,就尽量用软引用。因此,这一点可以很好地用来解决OOM的问题,并且这个特性很适合用来实现缓存:比如网页缓存、图片缓存等。这里还是以缓存Bitmap为例:
SoftReference<Bitmap> softReference =new SoftReference<Bitmap>(bitmap); Bitmap bitmap = softReference.get();
3.WeakReference(弱引用)
  弱引用也是用来描述非必需对象的,当JVM进行垃圾回收时,无论内存是否充足,都会回收被弱引用关联的对象,WeakReference 的强度又明显低于 SoftReference,所以如果该对象不被使用的可能性更大些,就可以用弱引用。还是以缓存Bitmap为例:
WeakReference<Bitmap> weakReference =new WeakReference<Bitmap>(bitmap); Bitmap bitmap1 = weakReference.get();
4.PhantomReference(虚引用)
 虚引用和前面的软引用、弱引用不同,它并不影响对象的生命周期。如果一个对象与虚引用关联,则跟没有引用与之关联一样,在任何时候都可能被垃圾回收器回收。还是以缓存Bitmap为例:
ReferenceQueue<Bitmap> queue =new ReferenceQueue<Bitmap>(); PhantomReference<Bitmap> phantomReference = new PhantomReference<Bitmap>(bitmap); Bitmap bitmap2 = phantomReference.get();

 非UI线程处理Bitmap(可以替换为其它对象)
class BitmapWorkerTask extends AsyncTask {
private final WeakReference imageViewReference; //注意用了final
private int data = 0;

public BitmapWorkerTask(ImageView imageView) {
// 使用WeakReference确保ImageView能被回收
imageViewReference = new WeakReference(imageView);
}

// Decode image in background.
@Override
protected Bitmap doInBackground(Integer... params) {
data = params[0];
return decodeSampledBitmapFromResource(getResources(), data, 100, 100));
}

// 完成后,看ImageView是否仍还在,在UI中更新.
@Override
protected void onPostExecute(Bitmap bitmap) {
if (imageViewReference != null && bitmap != null) {
final ImageView imageView = imageViewReference.get();
if (imageView != null) {
imageView.setImageBitmap(bitmap);
}
}
}
}

管理Activity与Handler通信

TIP:如果没有持有外部类的引用,将handler定义为statitc即可
//用静态内部类来防止持有外部类的隐性引用
static class WeakReferenceHander extends Handler {
//把Acitivity用WeakReference管理起来
private final WeakReference<ShareUploadActivity> mActivity;

public WeakReferenceHander(ShareUploadActivity activity) {
mActivity = new WeakReference<ShareUploadActivity>(activity);
}

@Override
public void handleMessage(Message msg) {
if (mActivity.get() != null) {
mActivity.get().handleReceiveMessage(msg);
}
}
}
阅读全文
0 0
原创粉丝点击