问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

Android Studio性能测试工具Profiler详解

创作时间:
作者:
@小白创作中心

Android Studio性能测试工具Profiler详解

引用
CSDN
1.
https://m.blog.csdn.net/xiaopei_yan/article/details/144373575

性能优化问题,在开发时经常会遇到。特别是在小厂或对性能要求不高的情况下,开发者可能很少进行性能优化。在性能优化方面,通常通过开发经验和性能分析工具来发现问题。本文将介绍Android Studio中的Profiler工具,帮助开发者了解应用的CPU、内存、网络和电池资源使用情况。

Profiler工具的功能

Profiler是评估代码性能的工具,主要帮助开发人员识别和解决代码中的性能问题,以提高应用程序的响应速度和效率。通过使用Profiler,开发人员可以了解应用程序的内部工作方式,从而进行优化和改进。Profiler和开发之间的关系是相互依存的。

性能优化的目的

优化程序的主要目的是使程序更健壮、效率更高,提供更快更流畅的用户体验,并延长设备电池续航时间。

Profiler的打开方式

Profiler工具可以通过以下三种方式打开:

  1. 点击AS左上角View / Tool Windows / Profiler
  2. 点击AS右上角的Profiler图标
  3. 点击AS最下面的Profiler按钮

三种打开方式如下图所示:

Profiler工具的三大分析方向

Profiler工具主要提供三大分析方向:

  • CPU分析
  • 内存分析
  • 能耗分析

三种分析方向如下图所示:

Profiler CPU分析

当打开CPU性能分析器时,它会立即开始显示应用的CPU使用率和线程活动,如下图所示:

  1. 事件时间轴:显示应用中的activity在其生命周期内不断转换经历各种不同状态的过程,并指示用户与设备的交互,包括屏幕旋转事件。如需了解如何在搭载Android 7.1(API级别25)及更低版本的设备上启用事件时间轴,请参阅启用高级性能分析功能。
  2. CPU时间轴:显示应用的实时CPU使用率(以占总可用CPU时间的百分比表示)以及应用当前使用的线程总数。此时间轴还会显示其他进程(如系统进程或其他应用)的CPU使用率,以便可以将其与应用的CPU使用率进行对比。可以通过沿时间轴的横轴方向移动鼠标来检查历史CPU使用率数据。
  3. 线程活动时间轴:列出属于应用进程的每个线程,并使用下面列出的颜色在时间轴上指示它们的活动。记录轨迹后,可以从时间轴上选择一个线程,以在轨迹窗格中检查其数据。
  • 绿色:表示线程处于活动状态或准备使用CPU。也就是说,线程处于正在运行或可运行状态。
  • 黄色:表示线程处于活动状态,但它正在等待一项I/O操作(如磁盘或网络I/O),然后才能完成它的工作。
  • 灰色:表示线程正在休眠且没有消耗任何CPU时间。当线程需要访问尚不可用的资源时,就会出现这种情况。在这种情况下,要么线程主动进入休眠状态,要么内核将线程置于休眠状态,直到所需的资源可用。
    CPU性能分析器还会报告Android Studio和Android平台添加到应用进程的线程的CPU使用率,这些线程包括JDWP、Profile Saver、Studio:VMStats、Studio:Perfa和Studio:Heartbeat等(不过,它们在线程活动时间轴上显示的确切名称可能有所不同)。Android Studio报告此数据是为了方便确定线程活动和CPU使用率什么时候是由应用的代码实际引发的。

Profiler内存分析

内存性能分析图说明:

  1. 用于强制执行垃圾回收事件的按钮
  2. 用于捕获堆转储的按钮
  3. 用于指定性能分析器多久捕获一次内存分配的下拉菜单
  4. 用于缩放时间轴的按钮
  5. 用于跳转到实时内存数据的按钮
  6. 事件时间轴,显示活动状态、用户输入事件和屏幕旋转事件
  7. 内存使用量时间轴,它会显示以下内容:
  • 一个堆叠图表,显示每个内存类别当前使用多少内存,如左侧的y轴以及顶部的彩色键所示。
  • 一条虚线,表示分配的对象数,如右侧的y轴所示。
  • 每个垃圾回收事件的图标。

Profiler能耗分析

当打开能耗性能剖析器时,它会立即开始显示应用的估算耗电量,如下图所示,下图是从官网找的图片介绍:

能耗性能剖析器的默认视图包括以下时间轴:

  1. “Event”时间轴:显示应用中的Activity在其生命周期内不断转换而经历各种不同状态的过程。此时间轴还会指示用户与设备的交互,包括屏幕旋转事件。
  2. “Energy”时间轴:显示应用的估算耗电量。
  3. “System”时间轴:显示可能会影响耗电量的系统事件。

如需查看CPU、网络和位置信息(GPS)资源,以及相关系统事件的具体耗电量情况,请将鼠标指针放在Energy时间轴中的条形上方。

如果需要学习更多的Profiler知识,可以去Profiler官网文档中进行更加详细的了解。

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号