更新到adt2.0的开发者们可能会在handler上发现这么一条警告:ThisHandlerclassshouldbestaticorleaksmightoccur

   首先在ADT20Changes我们可以找到这样一个变化:NewLintChecks:

Lookforhandlerleaks:Thischeckmakessurethatahandlerinnerclassdoesnotholdanimplicitreferencetoitsouterclass.

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

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

知道了原因我们在来看解决方法:
1.最不想动代码的同学,可以在Preference搜一下Lint,在LintErrorChecking里搜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的innerClassMyHandler然后让它持有Activity的弱引用。这样lintwarning就消失了。

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!

更多相关文章

  1. Android中Context和Resource之间的关系
  2. Android开发面试经——常见面试官提问Android题②
  3. Android(安卓)Content Provider在应用程序之间共享数据的原理分
  4. 《转载》android context 与内存泄露
  5. android 添加自定义theme和style
  6. android开机动画播放流程
  7. 疯狂安卓Android自学笔记
  8. Android(安卓)几种网络请求的区别与联系
  9. android 绘制文本居中

随机推荐

  1. Java&Xml教程(七)使用JDOM修改XML文件内容
  2. 疯狂XML学习笔记(11)-----------XSLT讲解
  3. Java&Xml教程(六)使用JDOM解析XML文件
  4. 疯狂XML学习笔记(10)---------XML的作用
  5. Java&Xml教程(五)使用SAX方式解析XML文件
  6. 疯狂XML学习笔记(9)-------------Schema内
  7. Java&Xml教程(四)使用DOM方式生成XML文件
  8. 疯狂XML学习笔记(8)---------schema 的简单
  9. Java&Xml教程(三)使用DOM方式修改XML文件内
  10. 疯狂XML学习笔记(7)-----------XML Schema