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

Android Traceview 定位卡顿问题

Traceview 是一个 Android 性能分析工具,用于时间性能分析,主要帮助开发者了解应用程序中各个方法的执行时间和调用关系。Traceview 可以通过图形化界面查看应用程序的代码执行细节,包括每个方法的调用次数、方法调用的时间消耗、方法调用堆栈等信息。

它是一种基于调用栈的分析方式,记录下应用程序在某个时间段内的函数调用情况。我们可以通过 Traceview 来定位性能瓶颈、不必要的函数调用,优化代码结构以及性能。


使用 Traceview 工具需要在代码中插入开始和结束追踪的方法:

Debug.startMethodTracing():开启监控

Debug.stopMethodTracing():停止监控

记录完成后,会生成一个.trace 文件,路径默认是/sdcard/Android/data/包名/files/dmtrace.trace

可以用 Android Studio 内置的 Profiler 工具来查看这个文件的可视化报告。


举个例子,在 MainActivity 中搞一个耗时操作:

class MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)findViewById<Button>(R.id.btn).setOnClickListener {Debug.startMethodTracing() // 开启监控longTimeOperation()Debug.stopMethodTracing()  // 关闭监控,生成 .trace 文件}}private fun longTimeOperation() {for (i in 0..10000) {Log.i("wk", "循环:$i")}Log.i("wk", "完成")}
}

点击 btn 后,首先开启监控,执行耗时操作后关闭监控,就会在默认的路径下生成 .trace 文件,把它保存在电脑本地(右键 -> Save As...)

然后把这个 trace 文件直接拖进 Android Studio,它会自动使用 Profiler 打开:

在实际项目开发当中,会有比较多的线程,这里选择主线程(main)和火焰图(Flame Chart)查看主线程调用的代码执行细节:

 从火焰图中就可以得知:com.demo.traceview.MainActivity.longTimeOperation 这个方法比较耗时,我们就可以按照这个路径跟踪到方法里面去进行优化(比如放子线程等)


除了使用代码生成 trace,还可以使用 Profiler 生成:

在 Profiler 中选择好要监控的进程后,点击 CPU 模块

 选择 Java/Kotlin Method Trace 后点击 Record 开始监控,手动进行耗时操作后点击 Stop 停止监控,它就会自动生成 trace 文件并打开,页面和步骤就跟上面的一样了


需要注意的是,因为 Traceview 会在运行时植入额外的检测代码,所以它会对应用程序的性能造成一定影响,所以一般不在生产环境中使用,只在开发阶段作为性能调试使用。

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

相关文章:

  • 第三方 Cookie 被禁用?企业该如何实现用户精准运营和管理?
  • Autosar PNC网络管理配置(2)-基于ETAS软件
  • 【SpringMVC快速使用】1.@RestController @RequestMapping 2.logback的使用
  • C2593 operator << 不明确
  • vue:使用【3.0】:条件模块
  • Kafka与RabbitMQ的区别
  • C++力扣题目538--把二叉搜索树转换为累加树
  • 曲线生成 | 图解贝塞尔曲线生成原理(附ROS C++/Python/Matlab仿真)
  • 【一万字干货】一篇给你讲清楚智慧城市——附送智慧系列开发项目合集
  • 关于如何禁用、暂停或退出OneDrive等操作,看这篇文件就够了
  • Vue3-46-Pinia-获取全局状态变量的方式
  • 数据库——DAY1(Linux上安装MySQL8.0.35(网络仓库安装))
  • 原生微信小程序-两次设置支付密码校验,密码设置二次确认
  • 【Python学习】Python学习15-模块
  • ARCGIS PRO SDK 设置UI控件状态:启用/禁用
  • 案例126:基于微信小程序的民大食堂用餐综合服务平台
  • cephfs 配置 mds stancd replay 操作
  • 【2023我的编程之旅】系统学习C语言easyx图形库心得体会
  • 【linux】软链接创建(linux的快捷方式创建)
  • 基于BP神经网络的光伏发电预测
  • RPA财务机器人在厦门市海沧医院财务管理流程优化汇总的应用RPA全球生态 2024-01-05 17:27 发表于河北
  • 应用在LCD显示器电源插头里的氮化镓(GaN)MTC-65W1C
  • Vue新手村(二)
  • Mysql-redoLog
  • 编程笔记 html5cssjs 039 CSS背景示例
  • 沃尔玛如何通过安全、有效的测评补单提升产品权重?
  • 「 典型安全漏洞系列 」03.跨站请求伪造CSRF详解
  • 区间合并(pair,auto的用法)
  • Java零基础教学文档第四篇:HTML_CSS_JavaScript(2)
  • 2024 年 Linux 和开源的六大趋势预测