谈谈handler的内存泄露问题
再来看看我们的新建Handler的代码:
private Handler mHandler = new Handler() { @Override public void handleMessage(Message msg) { ... } };
- 当使用内部类(包括匿名类)来创建Handler的时候,Handler对象会隐式地持有Activity的引用。
而Handler通常会伴随着一个耗时的后台线程一起出现,这个后台线程在任务执行完毕后发送消息去更新UI。然而,如果用户在网络请求过程中关闭了Activity,正常情况下,Activity不再被使用,它就有可能在GC检查时被回收掉,但由于这时线程尚未执行完,而该线程持有Handler的引用(不然它怎么发消息给Handler?),这个Handler又持有Activity的引用,就导致该Activity无法被回收(即内存泄露),直到网络请求结束。
另外,如果执行了Handler的postDelayed()方法,那么在设定的delay到达之前,会有一条MessageQueue -> Message -> Handler -> Activity的链,导致你的Activity被持有引用而无法被回收。
解决方法之一,使用弱引用:
static class MyHandler extends Handler { WeakReference<Activity > mActivityReference; MyHandler(Activity activity) { mActivityReference= new WeakReference<Activity>(activity); } @Override public void handleMessage(Message msg) { final Activity activity = mActivityReference.get(); if (activity != null) { mImageView.setImageBitmap(mBitmap); } } }
https://blog.csdn.net/ly502541243/article/details/52062179
其他handler的替代方案:
EventBus事件总线——优雅地替换Handler
https://blog.csdn.net/stimgo/article/details/52684390
RxJava线程切换代替Thread和Handler
https://www.jianshu.com/p/9d4e39a83a74
RxAndroid 进行封装实现替代Handler的方案
https://blog.csdn.net/z2wenfa/article/details/51276626
使用RxJava和RxAndroid封装RxBus,实现EventBus功能
https://blog.csdn.net/qq_33689414/article/details/51586250
给 Android 开发者的 RxJava 详解
http://gank.io/post/560e15be2dca930e00da1083