###1. 定义
优化处理 应用程序的内存使用、空间占用
###. 作用
避免因不正确使用内存 & 缺乏管理,从而出现 内存泄露(ML)、内存溢出(OOM)、内存空间占用过大 等问题,最终导致应用程序崩溃(Crash)
###3. 储备知识:Android 内存管理机制
####3.1 简介
下面,将针对回收 进程、对象 、变量的内存分配 & 回收进行详细讲解
###3.2 针对进程的内存策略
####a. 内存分配策略
由 ActivityManagerService 集中管理 所有进程的内存分配
###b. 内存回收策略
- 步骤1:Application Framework 决定回收的进程类型
Android中的进程 是托管的;当进程空间紧张时,会 按进程优先级低->>高的顺序 自动回收进程
Android将进程分为5个优先等级,具体如下:
- 步骤2:Linux 内核真正回收具体进程
ActivityManagerService 对 所有进程进行评分(评分存放在变量adj中)
更新评分到Linux 内核
由Linux 内核完成真正的内存回收
此处仅总结流程,这其中的过程复杂,有兴趣的读者可研究系统源码ActivityManagerService.java
###3.3 针对对象、变量的内存策略
- Android的对于对象、变量的内存策略同 Java
- 内存管理 = 对象 / 变量的内存分配 + 内存释放
下面,将详细讲解内存分配 & 内存释放策略
###a. 内存分配策略
- 对象 / 变量的内存分配 由程序自动 负责
- 共有3种:静态分配、栈式分配、 & 堆式分配,分别面向静态变量、局部变量 & 对象实例
- 具体介绍如下
注:用1个实例讲解 内存分配
public class Sample {
// 该类的实例对象的成员变量s1、mSample1 & 指向对象存放在堆内存中
int s1 = 0;
Sample mSample1 = new Sample();
// 方法中的局部变量s2、mSample2存放在 栈内存
// 变量mSample2所指向的对象实例存放在 堆内存
public void method() {
int s2 = 0;
Sample mSample2 = new Sample();
}
}
// 变量mSample3的引用存放在栈内存中
// 变量mSample3所指向的对象实例存放在堆内存
// 该实例的成员变量s1、mSample1也存放在堆内存中
Sample mSample3 = new Sample();
###b. 内存释放策略
- 对象 / 变量的内存释放 由Java垃圾回收器(GC) / 帧栈 负责
- 此处主要讲解对象分配(即堆式分配)的内存释放策略 = Java垃圾回收器(GC)
由于静态分配不需释放、栈式分配仅 通过帧栈自动出、入栈,较简单,故不详细描述
- Java垃圾回收器(GC)的内存释放 = 垃圾回收算法,主要包括:
具体介绍如下
###4. 常见的内存问题 & 优化方案
- 常见的内存问题如下
1、内存泄露
2、内存抖动
3、图片Bitmap相关
4、代码质量 & 数量
5、日常不正确使用
- 下面,我将详细分析每项的内存问题 & 给出优化方案
###4.1 内存泄露
-
简介
即 ML (Memory Leak),指 程序在申请内存后,当该内存不需再使用 但 却无法被释放 & 归还给 程序的现象 -
对应用程序的影响
容易使得应用程序发生内存溢出,即 OOM
内存溢出 简介:
发生内存泄露的本质原因
- 常见内存泄露原因
1、集合类
2、Static关键字修饰的成员变量
3、非静态内部类 / 匿名类
4、资源对象使用后未关闭
- 优化方案
具体请看文章:Android性能优化:手把手带你全面了解 内存泄露 & 解决方案
###4.2 图片资源Bitmap相关
-
优化原因
即 为什么要优化图片Bitmap资源,具体如下图:
-
优化方向
优化图片Bitmap资源,具体如下图:
[外链图片转存中…(img-m9iEWIdy-1650619156506)]
- 优化方向
[外链图片转存中…(img-k6qpuOp6-1650619156506)]