handler的性能优化之弱引用持有activity

Android 中handler机制太重要了,无时不刻的都在处理消息队列和任务队列,很多人不注意,在处理延时任务的时候持有activity,导致activity不能被早早的回收,从而降低了APP的效率和性能。
比如下面经典的写法(很多人都会这样写):

 new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                //TODO 大量操作
            }
        }, 5000);

这些细节都没有注意到性能的优化。
一般情况这样写:

 class MyHandler extends Handler {

        WeakReference mContext;

        public MyHandler() {
            mContext = new WeakReference<>(MainActivity.this);
        }

    }

然后在需要手动控制清除应用的时候这样写:

    //比如:在activity不可见的时候
    @Override
    protected void onStop() {
        super.onStop();
        handler.mContext.clear();
    }

当然这不是最好的写法,也有人在实例化handler的时候把它搞成静态的,这种可以达到高效的效果

还有一种写法也可以达到高效的效果:

 protected void onStop() {
        super.onStop();
     // handler.mContext.clear();
     //直接清空handler管道和队列,源码注释如下:
      /**
     * Remove any pending posts of callbacks and sent messages whose
     * obj is token.  If token is null,
     * all callbacks and messages will be removed.
     */
        handler.removeCallbacksAndMessages(null);
    }

总结:handler的对activity的持有,看个人灵活应用吧,不同条件达到最优化

你可能感兴趣的:(Android)