Android内存泄漏剖析之AsyncTask

#泄漏原因
一个常见的内存泄漏错误是AsyncTask有Activity或者Fragment的的强引用。

##错误示例##

下面是错误的,因为内部类隐式的含有父类的引用,这种情况下,通常是Activity和Fragment的引用。


class MyActivity extends Activity {
  private AsyncTask<Void, Void, Void> myTask = new AsyncTask<Void, Void, Void>() {
    //
  }
}

这个问题的产生原因是因为AsyncTask的生命周期通常比Activity长,例如=当任务时候,一些配置改变了。
#正确的使用AsyncTask方式

  1. AsyncTask变为静态内部类
    2.持有父类Activity或者Fragment的弱引用
    ##粗暴的代码##

class MyActivity extends Activity {
  static class MyTask extends AsyncTask<Void, Void, Void> {
    // 弱引用允许Activity被垃圾收集器清理
    private final WeakReference<MyActivity> weakActivity;

    MyTask(MyActivity myActivity) {
      this.weakActivity = new WeakReference<>(myActivity);
    }

    @Override
    public Void doInBackground(Void... params) {
      // do async stuff here
    }

    @Override
    public void onPostExecute(Void result) {
      // 重新获取Actiity的强引用,并且判断是否存活
      MyActivity activity = weakActivity.get();
      if (activity == null
          || activity.isFinishing()
          || activity.isDestroyed()) {
        // activity死亡了,不再做任何的事情
        return;
      }

      // The activity is still valid, do main-thread stuff here
    }
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值