Android开发之——Profiler-CPU性能分析(1)

  • 依次选择 View > Tool Windows > Profiler 或点击工具栏中的 Profile图标 img

  • 点击 CPU 时间轴上的任意位置以打开 CPU 性能剖析器

2.2 CPU 性能剖析器说明

CPU剖析图

剖析图说明
  1. 事件时间轴:显示应用中的 Activity 在其生命周期内不断转换经历各种不同状态的过程,并指示用户与设备的交互,包括屏幕旋转事件

  2. CPU 时间轴:显示应用的实时 CPU 使用率(以占总可用 CPU 时间的百分比表示)以及应用当前使用的线程总数

  3. 线程活动时间轴:列出属于应用进程的每个线程,并使用下面列出的颜色在时间轴上指示它们的活动

  • 绿色:表示线程处于活动状态或准备使用 CPU。也就是说,线程处于正在运行或可运行状态

  • 黄色:表示线程处于活动状态,但它正在等待一项 I/O 操作(如磁盘或网络 I/O),然后才能完成它的工作

  • 灰色:表示线程正在休眠且没有消耗任何 CPU 时间。 当线程需要访问尚不可用的资源时,就会出现这种情况

三 CPU捕获信息说明


3.1 捕获信息

3.2 捕获说明

  • 对 Java 方法采样:在应用的 Java 代码执行期间,频繁捕获应用的调用堆栈。分析器会比较捕获的数据集,以推导与应用的 Java 代码执行有关的时间和资源使用信息

  • 跟踪 Java 方法:在运行时检测应用,从而在每个方法调用开始和结束时记录一个时间戳。系统会收集并比较这些时间戳,以生成方法跟踪数据,包括时间信息和 CPU 使用率

  • 对 C/C++ 函数采样:捕获应用的原生线程的采样跟踪数据

  • 跟踪系统调用:捕获非常翔实的细节,以便您检查应用与系统资源的交互情况

四 记录跟踪数据


4.1 记录跟踪数据(跟踪java方法为例)

  • 选择记录跟踪数据类型,点击Record按钮开始记录

  • 记录采样一段时间后,点击Stop,停止记录跟踪

  • 停止后,进行结果数据分析

4.2 记录跟踪结果

记录跟踪结果图

说明
  1. 选定范围:确定需在跟踪数据窗格中检查所记录时间的哪一部分

  2. “Interaction”部分:沿着时间轴显示用户互动和应用生命周期事件

  3. “Threads”部分:沿时间轴针对每一个线程显示线程状态活动(例如运行、休眠等)和调用图表

  4. “Analysis”窗格:显示您选择的时间范围和线程/方法调用的跟踪数据

  5. “Analysis”窗格标签页:选择如何显示跟踪数据详细信息

  6. "Time reference"菜单:选择以下选项之一,以确定如何测量每次调用的时间信息(Wall clock timeThread time)

  7. Filter:按函数、方法、类或软件包名称过滤跟踪数据

五 导入导出数据


5.1 导出数据

  • 在Sessions列表中,点击会话条目右侧的 Export method traceExport system trace 按钮

  • 浏览到需保存文件的目标位置,指定文件名,然后点击 OK

5.2 导入数据

  • Sessions 窗格中点击 Start new profiler session 图标 img,然后选择 Load from file

  • Load from file后的效果如图

六 检查跟踪数据


6.1 Analysis 窗格

Analysis 窗格中查看 Flame ChartTop DownBottom UpEvents 标签页

各个内容说明:

  • Flame Chart 标签页提供一个倒置的调用图表,用来汇总完全相同的调用堆栈

  • Top Down 标签显示一个调用列表,在该列表中展开方法或函数节点会显示它的被调用方

  • Top Down 标签提供以下信息来帮助说明在每个调用上所花的 CPU 时间

  • Events表格列出了当前所选线程中的所有调用

最后笔者收集整理了一份Flutter高级入门进阶资料PDF

以下是资料目录和内容部分截图



里面包括详细的知识点讲解分析,带你一个星期入门Flutter。还有130个进阶学习项目实战视频教程,让你秒变大前端。


《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
714511893507)]
里面包括详细的知识点讲解分析,带你一个星期入门Flutter。还有130个进阶学习项目实战视频教程,让你秒变大前端。

[外链图片转存中…(img-NggmtFQR-1714511893508)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 21
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值