环境 Android Studio 4.1
利用 AS 自带工具分析内存分配情况
一 打开分析工具 Profiler
- 可以在 Help 中搜索关键字 Profiler
- 可以直接找到 View - Tool Windows - Profiler
- 打开过一次后,在底部直接打开
data:image/s3,"s3://crabby-images/7f1d7/7f1d707b26bbe3fa507c003e97217ebfc21dd3de" alt=""
二 Profiler 界面
右键底部的 Profiler tab,可以选择 View Mode,设置为 Windows 模式,独立成窗口模式,比较容易看(而且开发的一般有两个屏幕,把 Profile 窗口放到另外一个屏幕刚好一个屏幕看代码,一个屏幕看 Profiler 工具分析窗口)
data:image/s3,"s3://crabby-images/8d528/8d52825f21acc8cf26cd71d2a1871e61c85d57e8" alt=""
data:image/s3,"s3://crabby-images/e33c1/e33c1b75d04a5f4e47fdab587e51951f30d76be4" alt=""
三 开始录制分析内容
选择目标进程(或者打开 Profiler 工具,直接 Run 项目,就自动选择为当前 Run 的进程)
data:image/s3,"s3://crabby-images/3efd7/3efd7951010801f150c1492387afe8216ebab985" alt=""
data:image/s3,"s3://crabby-images/34bd9/34bd9eb572e6cb13a73630a4e1020565b624f976" alt=""
data:image/s3,"s3://crabby-images/cfebb/cfebbcc656643fb7ce14aeaa456b4411e4d28649" alt=""
data:image/s3,"s3://crabby-images/d8b7a/d8b7a496a7ac8ea4de8d5f68f8267a2025590e3e" alt=""
data:image/s3,"s3://crabby-images/fba04/fba04c9f6468fede87cd40462e2d5bfea6f20016" alt=""
data:image/s3,"s3://crabby-images/2d34a/2d34a95361cb48bdabdccea980aec383c5a432d5" alt=""
data:image/s3,"s3://crabby-images/e02e9/e02e9a57abc728ccc6ba8d459300d72f9fea041c" alt=""
data:image/s3,"s3://crabby-images/7090e/7090ef5818e0bec8f4114ff3abf327633eecdbd2" alt=""
接下来抓大头的分析各个线程的情况时,可以看到 6699 分配了 64次,总大小 29M多,然后查看该线程的任务,以排查代码中的问题(给线程起个名字是多么重要哇~)
四 一个例子
@Override
protected void onCreate(Bundle savedInstanceState) {
// ...
testThread.start();
}
private Thread testThread = new Thread(new Runnable() {
@Override
public void run() {
while (true) {
allocMethod();
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}, "alloc_thread");
private byte[] allocMethod() {
Log.d("test", "allocMethod:");
return new byte[(int) (1024 * 10)];
}
data:image/s3,"s3://crabby-images/48635/48635d235dc8a022ce96380f0688266e985b97bc" alt=""
五 最后
其实对象分配内存的次数可以有效分析一些内存问题,比如内存抖动等问题
当然,写个例子用来分析是非常简单的,但是实际项目中的问题定位起来肯定会异常地困难,这里的主要目的是解释如何使用这个工具进行分析而已。
网友评论