This Handler class should be static or leaks might occur
来源:互联网 发布:人工智能上市公司一览 编辑:程序博客网 时间:2024/06/10 01:42
更新到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);
}
- This Handler class should be static or leaks might occur
- This Handler class should be static or leaks might occur
- This Handler class should be static or leaks might occur
- This Handler class should be static or leaks might occur
- This Handler class should be static or leaks might occur
- This Handler class should be static or leaks might occur
- This handler class should be static or leaks might occur
- This Handler class should be static or leaks might occur
- This Handler class should be static or leaks might occur.
- The Handler class should be static or leaks might occur.
- This Handler class should be static or leaks might occur,Handler和Context使用的注意事项!
- 关于Handler 使用This Handler class should be static or leaks might occur 警告处理
- Android 关于Handler警告处理 This Handler class should be static or leaks might occur
- 关于Handler 使用This Handler class should be static or leaks might occur 警告处理
- This Handler class should be static or leaks might occur Android
- This Handler class should be static or leaks might occur Android
- This Handler class should be static or leaks might occur Android
- This Handler class should be static or leaks might occur Android
- 最小矩阵差——有上下界的网络流问题
- 点击Android主菜单应用,直接进入Dialog对话框
- 获得选中的checkbox的value
- JS中void(0)的含义
- MySQLReport分析报告四
- This Handler class should be static or leaks might occur
- lucene搜索小例子
- Android的线程使用来更新UI----Thread、Handler、Looper、TimerTask等
- 关于C++组合理解以及拷贝构造函数的调用时间的理解
- js匿名函数的执行
- DLL的概念、dll导出类
- pandaboard 跑 Android注意事项
- Android Button 的单击事件的三种响应方法
- Object Recognition and Scene Understanding(四)OpenCV SVM+HOG分类