- 依次选择 View > Tool Windows > Profiler 或点击工具栏中的 Profile图标
- 点击 CPU 时间轴上的任意位置以打开 CPU 性能剖析器
2.2 CPU 性能剖析器说明
CPU剖析图
剖析图说明
-
事件时间轴:显示应用中的 Activity 在其生命周期内不断转换经历各种不同状态的过程,并指示用户与设备的交互,包括屏幕旋转事件
-
CPU 时间轴:显示应用的实时 CPU 使用率(以占总可用 CPU 时间的百分比表示)以及应用当前使用的线程总数
-
线程活动时间轴:列出属于应用进程的每个线程,并使用下面列出的颜色在时间轴上指示它们的活动
-
绿色:表示线程处于活动状态或准备使用 CPU。也就是说,线程处于正在运行或可运行状态
-
黄色:表示线程处于活动状态,但它正在等待一项 I/O 操作(如磁盘或网络 I/O),然后才能完成它的工作
-
灰色:表示线程正在休眠且没有消耗任何 CPU 时间。 当线程需要访问尚不可用的资源时,就会出现这种情况
3.1 捕获信息
3.2 捕获说明
-
对 Java 方法采样:在应用的 Java 代码执行期间,频繁捕获应用的调用堆栈。分析器会比较捕获的数据集,以推导与应用的 Java 代码执行有关的时间和资源使用信息
-
跟踪 Java 方法:在运行时检测应用,从而在每个方法调用开始和结束时记录一个时间戳。系统会收集并比较这些时间戳,以生成方法跟踪数据,包括时间信息和 CPU 使用率
-
对 C/C++ 函数采样:捕获应用的原生线程的采样跟踪数据
-
跟踪系统调用:捕获非常翔实的细节,以便您检查应用与系统资源的交互情况
4.1 记录跟踪数据(跟踪java方法为例)
- 选择记录跟踪数据类型,点击Record按钮开始记录
- 记录采样一段时间后,点击Stop,停止记录跟踪
- 停止后,进行结果数据分析
4.2 记录跟踪结果
记录跟踪结果图
说明
-
选定范围:确定需在跟踪数据窗格中检查所记录时间的哪一部分
-
“Interaction”部分:沿着时间轴显示用户互动和应用生命周期事件
-
“Threads”部分:沿时间轴针对每一个线程显示线程状态活动(例如运行、休眠等)和调用图表
-
“Analysis”窗格:显示您选择的时间范围和线程/方法调用的跟踪数据
-
“Analysis”窗格标签页:选择如何显示跟踪数据详细信息
-
"Time reference"菜单:选择以下选项之一,以确定如何测量每次调用的时间信息(Wall clock time和Thread time)
-
Filter:按函数、方法、类或软件包名称过滤跟踪数据
5.1 导出数据
- 在Sessions列表中,点击会话条目右侧的 Export method trace 或 Export system trace 按钮
- 浏览到需保存文件的目标位置,指定文件名,然后点击 OK
5.2 导入数据
- Sessions 窗格中点击 Start new profiler session 图标
,然后选择 Load from file
- Load from file后的效果如图
6.1 Analysis 窗格
Analysis 窗格中查看 Flame Chart、Top Down、Bottom Up 和 Events 标签页
各个内容说明:
-
Flame Chart 标签页提供一个倒置的调用图表,用来汇总完全相同的调用堆栈
-
Top Down 标签显示一个调用列表,在该列表中展开方法或函数节点会显示它的被调用方
-
Top Down 标签提供以下信息来帮助说明在每个调用上所花的 CPU 时间
-
Events表格列出了当前所选线程中的所有调用
最后笔者收集整理了一份Flutter高级入门进阶资料PDF
以下是资料目录和内容部分截图
里面包括详细的知识点讲解分析,带你一个星期入门Flutter。还有130个进阶学习项目实战视频教程,让你秒变大前端。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
714511893507)]
里面包括详细的知识点讲解分析,带你一个星期入门Flutter。还有130个进阶学习项目实战视频教程,让你秒变大前端。
[外链图片转存中…(img-NggmtFQR-1714511893508)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!