1、ハンドラのメモリリーク
メモリリークの理由生成:ユーザが現在の活動を終了したときに得られ、外部のクラスを使用して匿名に保持された静的な内部クラスを、ハンドラ内の時間のかかる操作の数は、依然として活性で、その結果、実行されても、最終的に活性を導く行うハンドラを挙げとに残りましたスタックは、それがメモリリークにつながる、回収されていません。
解決策:外部活動の弱参照を保持1.handler内部。
2.ハンドラの代わりに、静的な内部クラスの。
3.活動の方法はonDestory mHandler.removeCallBack()によって失われます。
(わずか90%溶液)
private MyHandler mMyHandler = new MyHandler(this);
private static class MyHandler extends Handler{
// SoftReference<Activity> 也可以使用软应用 只有在内存不足的时候才会被回收
private final WeakReference<Activity> mActivity;
private MyHandler(Activity activity) {
mActivity = new WeakReference<>(activity);
}
@Override
public void handleMessage(Message msg) {
Activity activity = mActivity.get();
if (activity != null){
//做操作
}
super.handleMessage(msg);
}
}
private static final Runnable sRunnable = new Runnable() {
@Override
public void run() {
//做操作
}
};