Android_MVP优化
在使用的MVP框架模式可以看出它比MVC框架模式更加稳健,但是单纯的使用MVP还是有缺点的,因为Presenter持有了Activity的强引用,但是当presenter在加载数据时通常会有耗时操作,在耗时过程中如果Activity被销毁,那么此时presenter持有的MainActivity就无法被回收,此时就会导致内存泄露问题。为了解决内存泄露问题,可以为presenter提供弱引用。
1、创建抽象类 BasePresenter(使用泛型,为presenter持有view)
2、创建MVPBaseActivity(绑定Activity生命周期,两个泛型)
3、修改MainActivity
BasePresenter(在BasePresenter中设置弱引用)
/**
* Presenter控制基类
*/
public abstract class BasePresenter<T> {
/**
* 内存不足时释放内存
*/
protected WeakReference<T> mViewRef;
/**
* 绑定view
*/
public void attachView(T view){
mViewRef=new WeakReference<T>(view);
};
//用于在activity销毁时释放资源
public void detachView(){
if(mViewRef!=null){}
mViewRef.clear();
mViewRef=null;
};
protected T getView(){
return mViewRef.get();
}
}
MVPBaseActivity(MVP模式BaseActivity)
传递两个泛型一个View接口一个Presenter具体类,进行Activity生命周期关联,避免内存泄露
public abstract class MVPBaseActivity<V,T extends BasePresenter <V>> extends Activity {//Activity可以继承BaseActivity
public T mPresenter;
@SuppressWarnings("unchecked")
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
mPresenter=getPresenter();
//关联view
mPresenter.attachView((V)this);
}
@Override
protected void onDestroy() {
super.onDestroy();
//解关联view
mPresenter.detachView();
}
//具体的presenter由子类返回
protected abstract T getPresenter() ;
}
Presenter
public class Presenter extends BasePresenter<IFruitView>{
//需要持有View和Model接口
private IFruitView mFruitView;
private IFruitModel mFruitModel=new FruitModel();
public Presenter() {
super();
}
public void bind(){
mFruitView=getView();
mFruitModel.loadFruits(new IFruitModel.FruitOnloadListener() {
@Override
public void onLoadFinish(List<Fruit> fruits) {
mFruitView.showFruitView(fruits);
}
});
}
}