Android开发之性能测试工具Profiler

前言

性能优化问题,在我们开发时都会遇到,但是在小厂和对自己要求不严格的情况下,我都很少去做性能优化;

在性能优化上,基本大家都是通过自己的开发经验和性能分析工具来发现问题,今天给大家分享一下小编最近使用的Profiler工具

Profiler工具能做什么?

帮助开发者了解应用的CPU,内存,网络,电池资源等使用情况

Profiler与开发人员的关系?

Profiler是评估代码性能的工具,而开发是通过编写代码来实现功能的;

通过使用Profiler,开发人员可以识别和解决代码中的性能问题,以提高应用程序的响应速度和效率;

Profiler还可以帮助开发人员了解应用程序的内部工作方式,以便进行优化和改进;

Profiler和开发之间的关系是相互依存的;

性能优化的目的?

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

Profiler的打开方式

方式一:点击AS左上角View / Tool Windows / Profiler

方式二:点击AS右上角的Profiler图标

方式三:点击AS最下面的Profiler按钮

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

Profiler工具的三大分析方向

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

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

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 使用率,这些线程包括 JDWPProfile SaverStudio:VMStatsStudio: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官网文档中进行更加详细的了解

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Android Studio提供了多个工具来帮助开发者进行性能分析和优化。其中包括CPU Profiler和Memory Profiler。 CPU Profiler可以帮助开发者分析应用程序在CPU使用方面的性能问题。它可以显示应用程序中各个线程的CPU使用情况,包括一些由Android Studio和Android平台添加的线程,如JDWP、Profile Saver、Studio:VMStats、Studio:Perfa和Studio:Heartbeat。通过CPU Profiler开发者可以轻松识别出线程活动和CPU使用实际上是由应用程序代码引起的。要打开CPU Profiler,可以点击Android Studio的菜单栏中的View -> Tool Windows -> Android Profiler,然后选择要配置的设备和应用程序进程,最后点击CPU时间轴中的任意位置打开CPU Profiler。\[1\]\[2\] Memory ProfilerAndroid Profiler的一个组件,它可以帮助开发者识别应用程序中的内存泄漏和内存溢出问题。它可以实时显示应用程序的内存使用情况,并提供了捕获堆转储、强制垃圾收集和跟踪内存分配等功能。要启动Memory Profiler,可以点击Android Studio的菜单栏中的View -> Tool Windows -> Android Profiler,然后选择要配置的设备和应用程序进程,最后点击Memory Profile选项卡即可。\[3\] 通过使用这些Profiler工具,开发者可以更好地了解应用程序的性能状况,并进行相应的优化和调试。 #### 引用[.reference_title] - *1* *2* [Android studio中android profile(性能分析器)的使用(转载)](https://blog.csdn.net/u010259833/article/details/104441812)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Android Studio Memory Profile 的使用](https://blog.csdn.net/hello_1995/article/details/120069424)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

认真的小尹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值