**
===========================================================
Android中内存泄露无外乎两大方面的原因:
1. 非静态内部类默认持有外部类的引用
比如我们经常习惯直接在一个类里面对接口(interface)或抽象类(abstract)或者覆盖类中的方法(override),
这些情况我们称之为匿名内部类,而匿名内部类默认持有外部类的一个引用。
也就是说,非静态内部类的实例(也就是对象),会自动生成一个成员变量(也就是类定义的属性),这个成员变量会自动指向外部类的实例。
2. 静态对象
比如我们经常遇到的单例模式,在单例模式的构造函数中传入activity对象,从而导致存在于整个app生命周期中的单例对象一直持有这个activity的引用,导致这个activity不能被系统回收。
=============================================================
类的各个对象之间需要交互,则不可避免的导致相互之间的引用。
持有对象的引用,一般发生在如下的场景中:
- 声明内部类
内部类会默认有个成员变量(也就是实例变量),对象类型是外部类,也就是这是一个外部类对象的属性;
- 传参
将被引用的对象以参数的形式传入需要引用的对象当中,比如通过函数(构造函数、普通函数);
- 数据成员
将被引用的对象的引用,作为需要引用的对象中的一个数据成员,也就是作为需要引用的对象的成员变量(即实例变量);
这样需要引用的对象就可以对被引用对象的成员进行操作。
比如
public class Demo {
private A a;
…
}
这里的a这个Demo类的成员变量指向的是A这个实例,从而导致Demo这个对象对A对象产生了一个引用。
===================================================
资料获取→专栏
使用工具,这里推荐LeakCanary。
LeakCanary
这个工具用来检测Android内存泄露不二之选。
阅读LeakCanary的日志需要注意的几个地方:
9L2Rpc3NvbHZlLzcwL2dyYXZpdHkvU291dGhFYXN0?x-oss-process=image/format,png)
阅读LeakCanary的日志需要注意的几个地方: