当前位置: 首页 > news >正文

Android Perfetto 学习

1、如何抓取性能日志

方式1、通过手机里的System Tracing抓取
1、点击Settings->System->Developer options->System Tracing->Record trace 打开

2、操作完成后,点击Settings->System->Developer options->System Tracing->Record trace 关闭

3、弹出“trace saved”的通知后,可在手机目录/data/local/traces中获取抓取的perfetto-trace文件。

4、通过命令adb pull /data/local/traces将对应的systrace保存到本地。

2、如何分析性能日志

Perfetto网站

https://ui.perfetto.dev/

参考Android开发文档

https://developer.android.com/topic/performance/vitals/launch-time?hl=zh-cn

2.1 Trace文件介绍

2.1.1 CPU Info信息

        可以看到当前CPU负载情况,以及CPU任务工作栈

2.1.2 进程信息介绍

        查看对应APP进程,第一排表示进程相关状态,第二排表示主线程执行函数堆栈

2.2 进程相关状态

2.2.1 绿色 : 运行中(Running)

        表示进程正在CPU上运行

2.2.2 青色: 可运行(Runnable)

        线程可以运行但当前没有安排,在等待 cpu 调度

2.2.3 白色 : 休眠中(Sleeping)

        线程没有工作要做,可能是因为线程在互斥锁上被阻塞,也可能是其他原因。

尝试在APP代码中添加 sleep操作。

        会出现AcitivityStart函数执行有5S的休眠

        正常情况下AcitivityStart不会休眠。

2.2.4  橘色 : 不可中断的睡眠态 (Uninterruptible Sleep - IO Block)

        由于IO存储,导致现成处于休眠太,如果时间比较长,会造成卡顿问题

2.2.5 棕色 : 不可中断的睡眠态( Uninterruptible Sleep (non-IO))

3、Perfetto 工具的使用     

         可使用固定图标固定到最顶端

        添加删除时间轴

        

        其中代码栈中的函数打印是因为该函数添加了Trace Log打印,如果需要单独调试,可以自行添加Trace Log用于分析

        检索相关机制

http://www.lryc.cn/news/447039.html

相关文章:

  • ES数据的删除与备份
  • 论文解读《Object-Centric Learning with Slot Attention》
  • YOLOv8+注意力机制+PyQt5玉米病害检测系统完整资源集合
  • tcp、udp通信调试工具Socket Tool
  • MedPrompt:基于提示工程的医学诊断准确率优化方法
  • 关于ollama 在mac的部署问题
  • 职业技能大赛-单元测试笔记(assertThat)分享
  • AI大模型:OpenAI o1或能成为引领AI Phenomenal Ride的LLM新范式
  • 天命人,如何轻松利用仿真技术打造出属于你的“金箍棒”?
  • 【Qt | QAction】Qt 的 QAction 类介绍
  • 写论文一定要知道的三大AI工具!5分钟完成论文初稿
  • 时装购物|时装购物系统|基于springboot的时装购物系统设计与实现(源码+数据库+文档)
  • Android——内部/外部存储
  • 计算机网络发展
  • 【后端开发】JavaEE初阶—线程的理解和编程实现
  • Matlab simulink建模与仿真 第十九章(生成C代码)
  • 遍历9个格子winmine!StepBlock和遍历8个格子winmine!StepBox的对决
  • Python中的文件编码:揭开字符世界的神秘面纱
  • Vue3使用hiprint——批次打印条码
  • 智慧城市主要运营模式分析
  • 典型的MVC设计模式:使用JSP和JavaBean相结合的方式来动态生成网页内容典型的MVC设计模式
  • Vue引入js脚本问题记录(附解决办法)
  • 数据清洗与数据治理的关系
  • 树莓派pico上手
  • TypeError: load() missing 1 required positional argument: ‘Loader‘
  • 根据软件架构设计与评估的叙述开发一套机器学习应用开发平台
  • 【隐私计算篇】利用多方安全计算MPC实现VGG16人脸识别隐私推理
  • Python 入门教程(3)基础知识 | 3.7、pass 关键字
  • nodejs基于vue+express度假村旅游管理系统设计与实现7t82p
  • 【裸机装机系列】16.kali(ubuntu)-安装linux和win双系统-重装win11步骤