Android抓取trace的几种方式

一般在做性能优化时,我们喜欢用抓取火焰图的方式,来分析相关trace调用,发现对应的性能问题;最近在做启动优化,也尝试了几种不同的方式,遂记录下来

一、几种抓取火焰图的方式

Google对火焰图的介绍

1.使用AS的Profiler

developer.android.com/studio/prof...

  • 2024.1.2版本之前的抓取界面,在这个版本抓取时间一长就会卡死,而且没办法抓取启动阶段的火焰图,界面也不是很直观
  • 新版本改进了 Android Studio Profiler 的性能,Profiler也根据CPU、内存和功耗这种任务为中心进行了重新设计,也可以在打开 Profiler 后立即从用户界面启动系统跟踪任务,以分析并改进应用程序的启动时间。

2.使用perfetto来抓取

快速开始:perfetto.dev/docs/quicks...

  • 抓取到的火焰图类似下面这种,没有堆栈,原因是因为我们没有手动加trace
  • 如果提示adb连接失败,可以把Android Studio关闭,或者重新插拔usb
  • 网页的setting大家根据自己想手机的数据选择性开启即可,但一定要记得开启Perfetto SDK -> Tracek Event
  • 有些设备看不到对应的trace信息需要在设置中开启轨迹录制:blog.csdn.net/zhangphil/a...

二、如何自定义抓取trace

1.btrace

字节开源的高性能抓取trace方案,目前3.0版本采用同步抓栈和动态插桩的方案,整体抓取的粒度和准确度都是业内较高水平,但是目前还不支持多进程,具体用法可以参考github.com/bytedance/b...

2.插桩

一般正常的场景btrace就能满足诉求,但是如果有多进程的诉求或者编译冲突等更自定义的诉求,就需要自己添加trace;这个时候就要用到插桩的方案

  • 简单的trace抓取可以利用原生的能力

Trace#beginSection(String)Trace.endSection()

三、如何分析

1.人工分析

其实人工分析就全靠个人经验,

2.AI分析

目前市面上还没出相对应的产品,但是根据前面人工分析的步骤来看,按照如下思路不难实现一个非常好用的AI分析火焰图工具:

  • 根据GUI分析当前火焰图的全局情况(GPU/CPU等)
  • 结合SQL解析线程的耗时、binder的通信等
  • 再支持把代码库/片段作为上下文知识库传入
  • 结合分析火焰图的经验,通过LLM分析当前的卡顿、耗时和优化方案
相关推荐
Canace1 天前
使用大模型来维护知识库
前端·人工智能
HashTang1 天前
用自然语言驱动的开源 3D 建筑设计编辑器-Aedifex
前端·github·ai编程
0vvv01 天前
2026-NCTF-web-N-RustPICA
前端·ctf
前进的李工1 天前
MySQL角色管理:权限控制全攻略
前端·javascript·数据库·mysql
芯智工坊1 天前
第13章 Mosquitto监控与日志管理
前端·网络·人工智能·mqtt·开源
洒满阳光的庄园1 天前
Electron 桌面端打包流程说明
前端·javascript·electron
Jagger_1 天前
模型能力边界外扩时,工作到底在怎样被重做?
前端
SuperEugene1 天前
前端通用基础组件设计:按钮/输入框/弹窗,统一设计标准|组件化设计基础篇
前端·javascript·vue.js·架构
Jagger_1 天前
# 模型边界往外推的时候,我最怕的不是学不会,是没人听我解释
前端
OpenTiny社区1 天前
Chrome 内置「AI 外挂」?NEXTSDK 让浏览器自己调 API、抓数据、填表单!
前端