AS3.0 Profiler 性能分析利器

栏目: JavaScript · 发布时间: 6年前

内容简介:今年早些时候as升级到了3.0版本,自己前两天升级了,发现之前我们熟悉的 Android Monitor 不在了,取而代之的是Android Profiler,就参照官方文档过了一遍。1.点击工具栏的图标即可打开在Android Profiler窗口的顶部,如图所示,选择设备

今年早些时候as升级到了3.0版本,自己前两天升级了,发现之前我们熟悉的 Android Monitor 不在了,取而代之的是Android Profiler,就参照官方文档过了一遍。

1:Android Profiler的是使用流程:

1.点击 工具 栏的图标即可打开

AS3.0 Profiler 性能分析利器

在Android Profiler窗口的顶部,如图所示,选择设备

1

和你想要配置的app进程

2

当我们连接一个设备后,打开Android Profiles运行我们的应用程序时,它会默认选中我们的程序, Android Profiler显示如图1(图片来自官网),

AS3.0 Profiler 性能分析利器

如果我们连接了多个设备可以在按钮

1

的位置选择设备,通过按钮

2

的位置选择想要的app进程,工具最底部显示了一个时间轴,其中包含了CPU、内存和网络使用的实时图。该窗口还包括时间轴缩放控制按钮

3

,一个跳转到实时更新的按钮

4

,以及显示活动状态、用户输入事件和屏幕旋转事件

5

的事件时间轴。

我们想要查看对应工具详细的分析工具,只要单击性能数据相对应的图即可。下看看对应工具详细的使用。

2:内存工具

2.1内存工具简述(Memory Profiler)

我们打开Memory Profiler后界面如下图(图片来自官网)

AS3.0 Profiler 性能分析利器

如图所示,内存剖析器的默认视图包括以下内容:

1

:强制执行垃圾收集事件的按钮

2

:捕获堆转储的按钮

3

:一个记录内存分配的按钮,当连接到运行Android7.1或更低的设备时,该按钮才会出现

4

:放大/退出时间线按钮

5

:可以跳转到实时内存数据的按钮。

6

:事件时间轴,显示活动状态、用户输入事件和屏幕旋转事件。

7

:内存使用时间线,包括以下内容: 一个堆叠图,显示每个内存类别的内存大小,如左侧的y轴和顶部的颜色键。 虚线表示已分配对象的数量,如右侧的y轴所示。 每个垃圾收集事件的图标

2.2:内存计算指标

根据Android系统,你在内存分析器的顶部看到的数字(如下图)基于你的应用所提交的所有私有内存页面。此计数不包括与系统或其他应用程序共享的页。

AS3.0 Profiler 性能分析利器

内存类别如下:

  • Java:从 Java 或Kotlin代码中分配的对象的内存
  • Native:从C或c++代码中分配的对象的内存,即使你没有在app中使用c++,你可能会看到一些本地内存,因为Android框架使用Native内存来处理各种任务,比如处理图像资产和其他图形——即使你写的代码是Java或Kotlin
  • Graphics:用于图形缓冲区队列的内存用于显示屏幕上的像素,包括GL表面、GL纹理等。(注意,这是与CPU共享的内存,而不是专用的GPU内存)
  • Stack:在你的应用程序中,Native和Java栈使用的内存。这通常与你的应用程序运行的线程数有关
  • Code:您的应用程序用于代码和资源的内存,如dex字节码,优化或编译的dex代码。所以库和字体
  • Other:应用程序使用的内存,系统不确定如何分类
  • Allocated:应用程序分配的Java/Kotlin对象的数量。这并不计算用C或c++分配的对象

注意:当前应用程序中,native内存统计值可能会偏大,因为分析工具的一部内存也被算进去了,多达10MB的内存被添加到~100k对象,在未来版本的工具中,这些数字将从您的数据中过滤出来。

2.3:查看内存分配情况

单击工具栏记录内存分配在内存分析器 我们想要查看某一时刻程序的内存分配情况也很简单,如下图:

AS3.0 Profiler 性能分析利器

最后的界面如下图

AS3.0 Profiler 性能分析利器

2.4 捕获heap dump

heap dump显示在你捕获heap dump时应用程序中的哪些对象正在使用内存,特别是在扩展的用户会话之后,heap dump可以通过显示仍在内存中的对象来帮助识别内存泄漏。一旦捕获heap dump,可以查看以下内容:

  • 应用分配了哪些类型的对象,以及每个对象的数量
  • 每个对象使用多少内存。
  • 每个对象的引用都被保存在你的代码中。
  • 调用堆栈分配对象的位置,(当您在录制分配时捕获heap dump 时,调用堆栈当前仅在Android 7.1中使用堆转储时才可用。

要捕获heap dump,在Memory Profiler工具栏中单击Dump Java heap按钮即可 在转储堆时,Java内存量可能会暂时增加,因为堆转储发生在和你的应用程序相同的进程,并需要一些内存来收集数据,heap dump出现在内存时间线下方,显示了堆中的所有类型,如图下图所示。

AS3.0 Profiler 性能分析利器

在图中可以看到Class Name列表,,在列表中可以看到以下信息:

  • Alloc Count:堆中的分配数量。
  • Native Size:此对象类型使用的Native内存总量(以字节为单位),此列仅适用于Android 7.0及更高版本。 你会在这里看到一些在Java中分配的对象的内存,因为Android为一些框架类(比如Bitmap)使用本地内存。
  • Shallow Size:此对象类型使用的Java内存总量(以字节为单位)
  • Retained Size:由于此类的所有实例而保留的内存总大小(以字节为单位)在class 列表顶部,可以使用左侧的下拉列表在下列堆转储之间切换
  • Default heap:当系统没有指定堆时。
  • App heap:你的应用程序分配内存的主要堆。
  • Image heap:系统引导映像,包含在引导期间预加载的类,这里的分配保证不会移动或消失,
  • Zygote heap:Android系统中的应用程序进程分支的写入时复制堆。

2.5 将 heap dump 保存为 HPROF

如果你想保存 heap dump为日后查看,导出heap dump到一个HPROF文件的话,如需要点击 Export capture to file按钮,如下图

AS3.0 Profiler 性能分析利器

如果你需要从Android HPROF文件格式转换为Java SE HPROF格式,可以使用hprof-conv工具进行转化,它的位置在 android_sdk/platform-tools/目录下,运行hprof-conv命令

hprof-conv heap-original.hprof heap-converted.hprof
CPU Profiler的默认视图包含以下内容::Event timeline:显示应用在他们的生命周期中不同状态间转换时的活动,并指示用户与设备的交互,包括屏幕旋转事件:CPU timeline:显示应用程序的实时CPU使用情况(占可用CPU总时间的百分比)以及应用程序正在使用的线程总数。时间表还显示了其他进程(如系统进程或其他应用程序)的CPU使用情况,因此您可以将其与应用程序的使用情况进行比较。可以通过沿着时间轴的横轴移动鼠标来检查历史CPU使用率数据。:Thread activity timeline:列出属于你的应用程序进程的每个线程,并使用下面列出的颜色在时间线上指示其活动。记录方法跟踪之后,可以从此时间线中选择一个线程,以在跟踪窗格中检查其数据。:Recording configurations:允许您选择以下选项之一来确定探查器如何记录方法跟踪。:Record button:开始和停止录制方法跟踪按钮 ### 4:网络分析工具(Network Profiler) 网络分析工具比较简单,界面如下图:窗口的顶部的处,可以看见wifi无线信号的强弱,在时间线上可以在处点击和拖动一部分的时间线来检测流量,然后在窗口中会显示所选时间段内收发的文件,包括文件名,大小,类型,状态和花费时间,你可以对窗口的列表根据列来进行排序。还可以查看所选时间段的详细拆分,拆分的timeline可以显示文件是什么时候收发的,点击窗口3的其中一个文件,可以在窗口中查看文件的详细信息。通过切换窗口

上方标签可以查看response data(响应数据), header information, or the call stack(调用栈)。


以上所述就是小编给大家介绍的《AS3.0 Profiler 性能分析利器》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

人人都是产品经理

人人都是产品经理

苏杰 / 电子工业出版社 / 2010年4月 / 45.00元

这是写给“-1到3岁的产品经理”的书,适合刚入门的产品经理、产品规划师、需求分析师,以及对做产品感兴趣的学生,用户体验、市场运营、技术部门的朋友们,特别是互联网、软件行业。作为一名“4岁的产品经理”,作者讲述了过去3年的经历与体会,与前辈们的书不同,本书就像你走到作者身边,说“嗨哥们!晚上有空吃个饭么,随便聊聊做产品的事吧”,然后作者说“好啊”。 书名叫“人人都是产品经理”,是因为作者觉得过......一起来看看 《人人都是产品经理》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具