前言
在 Android 中,内存泄露的现象十分常见; 而内存泄露导致的后果会使得应用Crash 本文将全面介绍 内存泄露的本质、原因 & 解决方案, 最终提供一些常见的内存泄露分析工具,希望你们会喜欢
1. 简介
内存泄漏即 ML (Memory Leak) 指 程序在申请内存后,当该内存不需再使用;但 却无法被释放&归还给程序的现象
2. 对应用程序的影响
容易使得应用程序发生内存溢出,即 OOM 内存溢出
简介:

3. 发生内存泄露的本质原因
具体描述:

- 特别注意 从机制上的角度来说, 由于 Java存在垃圾回收机制(GC), 理应不存在内存泄露;出现内存泄露的原因仅仅是外部人为原因 = 无意识地持有对象引用,使得 持有引用者的生命周期 > 被引用者的生命周期
4. 储备知识:Android 内存管理机制
4.1 简介

下面,将针对回收 进程、对象 、变量的内存分配 & 回收进行详细讲解
4.2 针对进程的内存策略
- a. 内存分配策略 由 ActivityManagerService 集中管理 所有进程的内存分配
- b. 内存回收策略
步骤1: Application Framework 决定回收的进程类型 Android中的进程 是托管的;当进程空间紧张时,会 按进程优先级低->>高的顺序 自动回收进程
Android 将进程分为5个优先等级,具体如下:

步骤2: Linux 内核真正回收具体进程 ActivityManagerService 对 所有进程进行评分(评分存放在变量adj中) 更新评分到Linux 内核 由Linux 内核完成真正的内存回收
此处仅总结流程,这其中的过程复杂,有兴趣的读者可研究系统源码ActivityManagerService.java
4.2 针对对象、变量的内存策略
- Android的对于对象、变量的内存策略同 Java
- 内存管理 = 对象 / 变量的内存分配 + 内存释放
下面,将详细讲解内存分配 & 内存释放策略
a. 内存分配策略
- 对象 / 变量的内存分配 由程序自动 负责
- 共有3种:静态分配、栈式分配、 & 堆式分配,分别面向静态变量、局部变量 & 对象实例
注:用1个实例讲解 内存分配
public class Sample {
int s1 = 0;
Sample mSample1 = new Sample();
// 方法中的局部变量s2、mSample2存放在 栈内存
// 变量mSample2所指向的对象实例存放在 堆内存
// 该实例的成员变量s1、mSample1也存放在栈中
public void method() {
int s2 = 0;
Sample mSample2 = new Sample();
}
}
// 变量mSample3所指向的对象实例存放在堆内存
// 该实例的成员变量s1、mSample1也存放在堆内存中
Sample mSample3 = new

本文详细探讨了Android内存泄露的本质、影响,指出Java的GC并不能完全防止内存泄露,主要原因是人为错误导致对象引用生命周期不匹配。文章讲解了Android内存管理策略,包括进程和对象的内存分配与回收,并列举了常见的内存泄露原因,如集合类、静态成员变量、非静态内部类等,提供了解决方案。此外,还介绍了MAT、Heap Viewer、Allocation Tracker、Memory Monitor和LeakCanary等内存分析工具。
最低0.47元/天 解锁文章
489

被折叠的 条评论
为什么被折叠?



