这几天在使用开源项目 Leakcanary 对 App 的内存泄露进行检测和改善,效果是明显的,这里总结一些让我印象深刻的内存泄露情况。
RecyclerView 引发的内存泄露
会发生这种情况的内存泄露,往往都是因为 RecyclerView
的 Adapter
活的比 RecyclerView
要长导致的,解决方法很简单,在 Activity
或 Fragment
的销毁方法里面调用下面的代码:
recyclerView.setAdapter(null);
这样子手动解除RecyclerView
和 Adapter
之间的引用即可修复这次的内存泄露,也看通过继承 RecyclerView
,重写它的 onDetachedFromWindow
方法:
@Override
protected void onDetachedFromWindow() {
super.onDetachedFromWindow();
if (getAdapter() != null) {
setAdapter(null);
}
}
TextWatcher 监听引发的内存泄露
这个内存泄露是我第一次遇到的:
这个是在公司的三星手机上面收集到的,通过在 Stack Overflow 上面查询,得知这个内存泄露貌似也是只会发生在某些低版本三星设备上面(公司的三星手机是 4.3 版本),不过上面也给出了解决方法:
- 给
TextView/EditText
设置hint
属性,这样子就不会发生内存泄露 - 解决
TextWatcher
的监听
InputMethodManager 引发的内存泄露
这个是遇到次数最多的内存泄露情况了,这个是这是 Android 输入法的一个 bug,在 15<=API<=23 中都存在,而且比较神奇的话,RecyclerView
偶尔也可以触发这个 bug 。