Android内存泄漏原因及解决方案(LeakCanary)
原因
Android中内存泄露无外乎两大方面的原因:
1. 非静态内部类默认持有外部类的引用
比如我们经常习惯直接在一个类里面对接口(interface)或抽象类(abstract)或者覆盖类中的方法(override),
这些情况我们称之为匿名内部类,而匿名内部类默认持有外部类的一个引用。
2. 静态对象
比如我们经常遇到的单例模式,在单例模式的构造函数中传入activity对象,从而导致存在于整个app生命周期中的单例对象一直持有这个activity的引用,导致这个activity不能被系统回收。
3. 谈谈引用
类的各个对象之间需要交互,则不可避免的导致相互之间的引用。
持有对象的引用,一般发生在如下的场景中:
1. 声明内部类
内部类会默认有个成员变量(也就是实例变量),对象类型是外部类,也就是这是一个外部类对象的属性;
2. 传参
将被引用的对象以参数的形式传入需要引用的对象当中,比如通过函数(构造函数、普通函数);
3. 数据成员
将被引用的对象的引用,作为需要引用的对象中的一个数据成员,也就是作为需要引用的对象的成员变量(即实例变量);
这样需要引用的对象就可以对被引用对象的成员进行操作。
解决方案
LeakCanary
这个工具用来检测Android内存泄露不二之选。
阅读LeakCanary的日志需要注意的几个地方:
1. 顺序
从上到下,最上面表示引用的起点,然后一层一层往下引用,最后一层表示泄露的对象。
2. 语法
Object$2.this$0
表示Object类里面的第2个匿名内部类,这个内部类中的成员变量(this$0);
Object$2.val$request
表示Object类里面的第2个匿名内部类,这个匿名内部类外部声明的临时变量val,变量名称为request;
一般可能这个变量是函数的一个参数。
上一篇: Python使用xlwt模块操作Excel的方法详解
下一篇: 局域网伪造源地址DDoS攻击解决方法
推荐阅读
-
Android内存泄漏排查利器LeakCanary
-
关于JVM内存溢出的原因分析及解决方案探讨
-
android 内存泄露分析及调试(LeakCanary使用)
-
JS常见内存泄漏及解决方案解析
-
Android Handler内存泄漏原因及解决方案
-
Android内存泄漏原因及解决方案(LeakCanary)
-
5个Android开发中比较常见的内存泄漏问题及解决办法
-
Android activity动画不生效原因及解决方案总结
-
Android自定义View5--getWidth()和getMeasuredWidth()区别, view.post(Runnable)引发内存泄漏的原因和解决
-
Android Native 内存泄漏系统化解决方案