Configuration Changes(旋转屏幕是其中一种)时,会销毁并重建Activity,使用AsyncTask常出现的问题有,AsyncTask还在运行,但是屏幕一旋转,Activity销毁并重建,这样的话很可能导致崩溃。
解决方式一. 使用worker fragment
老外有篇博文介绍了这个的实现,我把它称为worker fragment
将AsyncTask放置于Fragment中,将Fragment放到Activity中,使用Fragment.setRetainInstance(),这样做的话,旋转屏幕Fragment是不会重建的。
解决方式二. 使用eventBus之类的库
这篇文章介绍了,这里就不多做解释。
解决方式三. 使用WeakReference来实现。
AsyncTask的子类设置为static,同时持有Activity的弱引用,大概代码如下
public class DemoActivity extends ActionBarActivity{
MyTask mTask = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_demo);
mTask = new MyTask(this);
mTask.execute();
}
public void onMyTaskFinish(){
mTask = null;
// update UI
}
@Override
protected void onDestroy() {
if (mTask != null){
mTask.cancel(true);
mTask = null;
}
super.onDestroy();
}
static class MyTask extends AsyncTask<Void, Void, Void>{
WeakReference<DemoActivity> mContextRef;
public MyTask(DemoActivity context) {
super();
mContextRef = new WeakReference<DemoActivity>(context);
}
@Override
protected Void doInBackground(Void... params) {
// do some work
return null;
}
@Override
protected void onCancelled(Void result) {
// TODO Auto-generated method stub
super.onCancelled(result);
}
@Override
protected void onPostExecute(Void result) {
if (mContextRef != null && mContextRef.get() != null){
DemoActivity context = mContextRef.get();
if (context != null){
context.onMyTaskFinish();
}
}
super.onPostExecute(result);
}
}
}