Java内存泄露分析
非静态匿名内部类会持有外部类的引用,如果此时非静态内部类的生命周期与外部类不一致,如非静态内部类是一个异步线程过程,那么在线程执行过程中导致外部类无法被回收
匿名内部类默认继承或实现方法
非静态内部类会持有外部类的引用,此时如果内部类生命周期与外部类不一致则可能导致外部类无法被回收,如内部类被单例持有时,会导致外部类也一直被持有
静态内部类则不会持有外部类的引用
在列表或集合里,添加的对象都会被列表或集合持有,此时只有从列表或集合中移除元素或把列表或集合置空才能保证能够被回收
软引用在内存不足时才会被回收
弱引用在gc时就会被回收
因此软引用和弱引用都必须非空判断
单例模式由于生命周期非常长,因此如果不小心引用了其他对象会导致被引用的对象无法被回收,如果有这种情况,在单例里要开放将引用对象置空的接口,使得引用对象能被释放。
GC Root
- 会产生内存泄漏的主要就是那些GC Root对象
- 而线程就是一个GC Root对象
- 静态类也是一个GC root对象
- AsyncTask之所以有可能导致内存泄漏就因为它是一个线程
分析工具
java VisualVM,在jdk安装的bin目录下找到jvisualvm.exe
参考
Java中关于内存泄漏出现的原因汇总及如何避免内存泄漏(超详细版)
https://www.jb51.net/article/92311.htm
Java中的内部类(成员内部类、静态内部类、局部内部类、匿名内部类)
https://www.cnblogs.com/shen-hua/p/5440285.html
java中的基本数据类型存放位置
https://www.cnblogs.com/panxuejun/p/5970739.html