【实践】Memory Monitor使用

##一.可以做什么

  • 实时查看App的内存分配情况
  • 发现内存抖动的场景
  • 发现大内存对象分配的场景
  • 发现内存不断增长的场景
  • 确定卡顿问题是否因为执行了GC操作

##二.工作面板说明

[外链图片转存失败(img-ZfAVzLm2-1566995130725)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2009-49-00.png)]

[外链图片转存失败(img-3QzXlUE6-1566995130727)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2009-49-09.png)]

工作台介绍:

[外链图片转存失败(img-vEPfW9SG-1566995130728)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2009-49-28.png)]

[外链图片转存失败(img-avemme0y-1566995130729)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2009-49-48.png)]
Enable,暂停内存信息的收集,再次点击后恢复内存信息的收集

[外链图片转存失败(img-gfastY1k-1566995130729)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2009-49-53.png)]
Initiable GC,执行GC。GC就是垃圾回收的意思,我们可以从Memory monitor看到何时发生了GC event,当一个内存短时间内发生掉落,我们可以认为发生了GC操作。你也可以手动触发GC,下图中的小车子就是触发GC的按钮,一旦按下就会回收那些没被引用的对象。

[外链图片转存失败(img-ODKdFEWm-1566995130729)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2009-49-59.png)]
Dump Java Heap,获取当前JAVA堆快照

[外链图片转存失败(img-HUh4BHqq-1566995130730)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2009-50-04.png)]
Start Allocation Tracking,开始内存分析,再次点击后结束内存分析

[外链图片转存失败(img-9euVgArn-1566995130730)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2009-50-10.png)]
Memory monitor help,帮助

##三.hprof

heap dumps,中文翻译,堆转储,快照。即堆内存某个时刻的情况。

##四.Heap Snapshot面板:Androidstudio打开堆快照

[外链图片转存失败(img-F4RJnXG2-1566995130731)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2011-52-20.png)]

###下拉列表1

[外链图片转存失败(img-mV9MG2Io-1566995130733)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2011-59-15.png)]

  • App heap表示App的堆信息
  • Image heap表示UI的堆信息
  • Zygote heap表示Android核心Zygote进程的堆信息

一般选择App heap即可

###下拉列表2

[外链图片转存失败(img-YyfW2X2f-1566995130733)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2011-59-21.png)]

选择数据展示的方式

  • Class List View表示以类的方式
  • Package Tree View表示以包结构树的形式

###窗口1

[外链图片转存失败(img-SKFsclwZ-1566995130734)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2013-15-02.png)]

左上第一个窗口表示类的内存信息,默认以Retained Size由大到小排列

[外链图片转存失败(img-vdhB5NOt-1566995130734)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2013-16-09.png)]

###窗口2

单击选中左侧一个类之后,即会在右侧第二个窗口中显示该类实例出现的具体信息

[外链图片转存失败(img-KH9DCT06-1566995130739)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2013-16-57.png)]

[外链图片转存失败(img-kXu3Rw6b-1566995130739)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2013-17-55.png)]

###窗口3

单击选中一个实例后(窗口2),会在下方窗口出现实例的引用树

[外链图片转存失败(img-vS3fY3Tu-1566995130741)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2013-19-07.png)]

[外链图片转存失败(img-yL1ug187-1566995130743)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2013-20-02.png)]

通过AnalyzerTaskers分析内存泄露
单击左侧Analyzer Taskers标签页,即可打开Analyzer Tasker窗口

##五.案例

[外链图片转存失败(img-Vrfb9IEO-1566995130743)(http://7xvzr8.com1.z0.glb.clouddn.com/2017-07-13%2013-21-28.png)]

上面的第一段标记显示内存突然增加了7M,我们也能看的很清楚,所以这个点我们要去定位了一下问题在哪里,是Bitmap还是什么原因造成的,第二段标记是内存抖动,很明显在很短的时间了发生了多次的内存分配和释放。而且在发生内存抖动的时候,也能感觉到App的卡顿,可以看出来是由于执行了GC操作造成的。
内存的不断增加通过Memory monitor很容易看出来,蓝色的曲线是一路高歌猛进的,一看便知。

关于内存泄漏的问题
Memory Monitor也可以归纳到用于检测内存泄漏的工具,但是我没这么做,因为在实际过程中,当泄漏的点每一次很小的时候,你很难发现,没有Heap Viewer好使。如果泄漏的对象占用内存大的话,也能通过Memory Monitor看出来。

Android优化——和讯财道内存优化实践
http://blog.csdn.net/i7788/article/details/59102822

##参考资料

你可能感兴趣的:(android提高)