zoukankan      html  css  js  c++  java
  • android之lint警告This Handler class should be static or leaks might occur

       更新到adt2.0的开发者们可能会在handler上发现这么一条警告:This Handler class should be static or leaks might occur 

       首先在ADT 20 Changes我们可以找到这样一个变化:New Lint Checks:

             Look for handler leaks: This check makes sure that a handler inner class does not hold an implicit reference to its outer class.

             翻译过来就是,Lint会增加一个检查项目即:确保class内部的handler不含有外部类的隐式引用 

             同一个线程下的handler共享一个looper对象,消息中保留了对handler的引用,只要有消息在队列中,那么handler便无法被回收,如果handler不是static那么使用Handler的Service和Activity就也无法被回收。这就可能导致内存泄露。当然这通常不会发生,除非你发送了一个延时很长的消息。

             知道了原因我们在来看解决方法:
             1.最不想动代码的同学,可以在Preference搜一下Lint,在Lint Error Checking里搜HandlerLeak,然后选择ignore,然后整个世界清净了。。。。(不推荐)
             2.上面的方法虽然简单,但是肯定不好的。。。给这个检查肯定是有用的,那第二种方法,自然就是把Handler定义成static,然后用post方法把Runnable对象传送到主线程:例。
                   

     private static Handler handler;
    
                    public void onCreate(Bundle savedInstanceState) {
                            super.onCreate(savedInstanceState);
                            setContentView(R.layout.main); // Create a handler to update the UI
                            handler = new Handler();
                    }
    
                    void test() {
                            handler.post(new MyRunnable());// 这样的方法同样可以用 SmsPopupActivity.this.runOnUiThread(new MyRunnalble());来替换,效果是一样的。
                    }
    
                    static public class MyRunnable implements Runnable {
                            @Override
                            public void run() {
                                    imageView.setImageBitmap(downloadBitmap);
                                    dialog.dismiss();
                            }
                    } 

             3。看到这种方式可能又有很多人不乐意了,原来我一个handler处理多个消息,多舒服,你现在要我把每个消息都换成对应的Runnable对象发送,多不爽。
    那我们可以通过弱引用的方式来做,例子如下示:我们首先定义了一个static的inner Class MyHandler然后让它持有Activity的弱引用。这样lint warning就消失了。
            

    static class MyHandler extends Handler {
                    WeakReference<PopupActivity> mActivity;
    
                    MyHandler(PopupActivity activity) {
                            mActivity = new WeakReference<PopupActivity>(activity);
                    }
    
                    @Override
                    public void handleMessage(Message msg) {
                            PopupActivity theActivity = mActivity.get();
                            switch (msg.what) {
                            case 0:
                                    theActivity.popPlay.setChecked(true);
                                    break;
                            }
                    }
            };
    
            MyHandler ttsHandler = new MyHandler(this);
            private Cursor mCursor;
    
            private void test() {
                    ttsHandler.sendEmptyMessage(0);
            }

    转自eoe!

  • 相关阅读:
    e生保plus
    Exception analysis
    经验总结:5个应该避免的前端糟糕实践
    经验总结:应对中文输入法的字符串截断方案(带代码示例)
    这些年那些文
    fis入门-单文件编译之文件优化(optimize)
    《HTTP权威指南》读书笔记:缓存
    npm install —— 从一个简单例子,看本地安装与全局安装的区别
    chrome下的Grunt插件断点调试——基于node-inspector
    Yeoman的好基友:Grunt
  • 原文地址:https://www.cnblogs.com/fanglove/p/2950102.html
Copyright © 2011-2022 走看看