handler使用WeakReference

如果引用对象生命周期长于本来应该释放的对象的话,那就会引起内存泄露(handle持有外部类Activity的引用,我们知道消息队列是在一个Looper线程中不断轮询处理消息,那么当这个Activity退出时消息队列中还有未处理的消息或者正在处理消息,而消息队列中的Message持有mHandler实例的引用,mHandler又持有Activity的引用,所以导致该Activity的内存资源无法及时回收,引发内存泄漏。)
baseActivity中

protected MyHandler handler = new MyHandler(this);
public abstract void handlerMessage1(Message msg);
public static class MyHandler extends Handler {
        private WeakReference weakReference;
        public MyHandler(BaseActivity activity) {
            this.weakReference = new WeakReference(activity);
        }
        @Override
        public void handleMessage(Message msg) {
            weakReference.get().handlerMessage1(msg);
        }
    }

其他子类Activity中

//发送message信息
Message msg = Message.obtain();
        msg.what = flag;
        msg.obj = result;
        handler.sendMessage(msg);
//处理message信息     子类实现父类的抽象方法handlerMessage1()
    @Override
    public void handlerMessage1(Message msg) {
            progressDialog.dismiss();
            getSearchData((ResultDesc) msg.obj,msg.what);
    }

由于Handler持有的对象是使用弱引用,根据WeakReference弱引用的特点在GC回收时能回收弱引用,这样就避免了OOM,另外还有在消息队列中可能会有待处理的消息Message,所以我们可以在onDestroy()或者onStop()中调用mHandler.removeCallbacksAndMessages(null);来移除所有消息和Runnable

常见内存泄露的原因

•非静态匿名内部类和非静态内部类会引用外部类。
•回调有可能会引起内存泄露,如果回调对象被静态对象引用或者其他原因引用而无法释放,就会导致内存泄露。
•Dialog有可能引发泄露
•非静态Handler引用外部类引起内存泄露
•线程,动画等无限循环执行,引用了需要释放的对象,也会引起内存泄露
•静态成员集合类和静态View对象 以及静态的非静态成员变量
•单例类
•资源未关闭导致的泄露。BroadcastReceiver未解除注册

你可能感兴趣的:(handler使用WeakReference)