Android Studio 中Android Monitor 很强大,有5个模块,Memory、Network、logcat、CPU、GPU。

android monitor

内存检测 memory

memory

这个可以检测内存泄漏,如果这个值稳定,没有很大的变动,说明没什么问题。

对于图中从左到右的四个五个按钮:第一个(Enabled)Memory的开关。如果选择关闭,则不对当前进程进行内存监测;第二个(Initiate GC)手动调用GC,我们在抓内存前,一定要手动点击 Initiate GC按钮手动触发GC,这样抓到的内存使用情况就是不包括Unreachable对象的;第三个(Dump Heap java)点击这个按钮的时刻,就在点击的时刻,将获取hprof文件(hprof文件也是我们使用MAT工具分析内存时经常使用的文件)若进行简单的数据分析用这个就可以,需要详细分析那么就得使用MAT工具,如图:

image.png

A 区域可以看类视图,class list view;或者包视图,package tree view。

B 区域对应的是A中选中类的实例对象。

C 区域是对应B中选中实例的引用链,dominating size可以看到占用的大小

第四个按钮(Start Allocaton Tracking)开始分配追踪,第一次点击可以指定追踪内存的开始位置,第二次点击可以结束追踪的位置。这样我们截取了一段要分析的内存,等待几秒钟AndroidStudio会给我们打开一个Allocation视图.

image.png

打开后我们可以看到各个线程中的方法所占用内存的大小

thread

image.png

NetWork:

Tx:上传网速

Rx:下载网速。

image.png

CPU

这个模块可以监控方法执行的时间轴,可以监测到每个方法的耗时,比较实用。

image.png

image.png

我们可以看到每个方法的执行时间,也可以看到自己写的方法,

Inclusive time - 函数本身运行花费时间 + 函数调用其他函数时间

Exclusive time - 函数本身运行花费时间。

Invocation count - 是调用次数。

如果app卡顿现象,那么用此模块可以快速定位出比较耗时的方法。

Wall Clock Time 和Thread Time的区别是,Wall Clock Time 包括了Thread Sleep的时间,而Thread Time不包括。

GPU

Logcat:打log绝对是调试中非常好用的工具了

image.png