博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
性能优化工具知识梳理(6) Memory Monitor & Heap Viewer & Allocation Tracker
阅读量:7094 次
发布时间:2019-06-28

本文共 2333 字,大约阅读时间需要 7 分钟。

一、概述

Memory Profilers是分析内存工具的集合,它包括以下三部分:

  • Memory Monitor Tool
  • Heap Viewer
  • Allocation Tracker

二、Memory Monitor

Memory MonitorAndroid Studio中自带的内存检测工具,它的作用有:

  • 实时检测应用的内存占用情况。
  • 检测卡顿是否是由于正在Gc引起。
  • 定位崩溃问题是否由内存问题引起。

这个工具位于Android Studio/Monitor一栏当中,前面我们在介绍MAT的时候曾经使用过它,首先编写一个简单的demo,通过它可以分配和回收内存:

public class TrackerObject {    List
mBitmaps = new ArrayList<>(); public void allocBitmaps() { for (int i = 0; i < 100; i++) { Bitmap bitmap = Bitmap.createBitmap(200, 200, Bitmap.Config.ARGB_8888); mBitmaps.add(bitmap); } } public void releaseBitmaps() { for (Bitmap bitmap : mBitmaps) { bitmap.recycle(); } mBitmaps.clear(); }}public class TrackerActivity extends Activity { private TrackerObject mTrackerObject; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_tracker); mTrackerObject = new TrackerObject(); } public void alloc(View view) { mTrackerObject.allocBitmaps(); } public void release(View view) { mTrackerObject.releaseBitmaps(); }}复制代码

  • 当我们点击alloc之后,内存不断上涨。
  • 而当我们点击release之后,内存并不会立刻下降,而是需要点击左边的“垃圾车”按钮来主动触发垃圾回收,这时候可以看到曲线立刻下降,说明此时触发了垃圾回收过程。
  • 视图中分为两个部分:
  • 深蓝色:App当前使用的内存。
  • 淡蓝色:已经分配给App,但是当前没有使用的内存。
  • 当我们不断点击alloc,最后就会抛出OOM异常错误:

三、Heap Viewer

Heap Viewer有点像是MAT的简化版,它是Android Device Monitor中的一个工具:

它的使用方式很简单,按照上图的步骤进行操作就可以了,需要特别注意的是,如果我们希望获得最新的内存占用情况时,那么需要做两件事:

  • 保证2中的开关是打开的
  • 点击5来触发一次Gc,这样才能得到最新的内存使用情况。

四、Allocation Tracker

Allocation Tracker是用来记录一段时间内的内存分配情况,并且它可以列出分配对象的大小,以及是由哪个函数分配的。 下面,我们先看一下如何使用:

其所处位置和上面的
Heap Viewer类似,其展现结果在
Heap的右边,当我们需要获得一段时间的内存分配,那么需要以下几步:

  • 点击start Tracking
  • 操作App,这里我们点击alloc按钮分配一些Bitmap
  • 点击Get Locations,获得从开始到结束的内存分配情况

各列值的含义:

  • Alloc Order:分配的顺序
  • Allocation Size:分配的大小
  • Allocated Class:分配对象的类名
  • Thread id:分配的线程id
  • Allocated in:分配到哪个对象当中。

在整个区域的最下方,则是分配该对象的函数调用堆栈信息,这也是这个工具最有用的地方,通过它我们就可以分析出是代码中哪一段逻辑导致了某个对象的分配。

五、小结

下面,我们来总结一下这三个工具各自的特点:

Memory Monitor

  • 显示内存占用、分配和回收情况。
  • 判断GC是否是造成应用卡顿的原因。
  • 判断是否是由于内存问题导致了App的崩溃。
  • 呈现的结果是实时的。
  • 能够有效地帮助分析内存泄露。
  • 定位Gc发生的时间,并分析这是否是合适的时间。
  • 没有列出具体的分配对象。

Heap Viewer

  • 在垃圾回收发生时,呈现出某一时刻的内存快照。
  • 帮助我们分析有可能是哪个对象引起了内存泄露。

Allocation Tracker

  • 分析出一段时间内对象的分配情况,并列出是由什么逻辑导致了这个对象的分配。
  • Heap Viwer一起使用,来分析大对象产生的原因。

六、参考文献


更多文章,欢迎访问我的 Android 知识梳理系列:

  • Android 知识梳理目录:
  • 个人主页:
  • 个人知识总结目录:

转载地址:http://ajaql.baihongyu.com/

你可能感兴趣的文章
placement new用法
查看>>
有的日期输入框,可直接调用javascripts
查看>>
手工创建表控制条目
查看>>
poj 2109 -- Power of Cryptography
查看>>
通过Navicat for MySQL远程连接的时候报错mysql 1130的解决方法
查看>>
Hive函数&压缩
查看>>
timestamp与timedelta,管理信息系统概念与基础
查看>>
第三章: Hotspot算法实现
查看>>
回归JDK源代码(2)Enumeration<E>接口
查看>>
python基础知识-04-字符串列表元组
查看>>
结对开发——求最大值
查看>>
爬虫体验
查看>>
对faster rcnn 中rpn层的理解
查看>>
廖雪峰js教程学习——操作表单
查看>>
uva 11354(最小瓶颈路--多组询问 MST+LCA倍增)
查看>>
简单聊下IO复用
查看>>
使用 Management Studio 进行连接
查看>>
GSS1 - Can you answer these queries I(线段树)
查看>>
Python脚本实现单据体背景色及字段前景色设置
查看>>
php-7.1.11编译选项配置
查看>>