android - 如何找出我的代码的哪些部分最常使用 UI 线程?

标签 android android-anr-dialog

我试图在没有任何堆栈跟踪的情况下追逐一些 ANR。我现在只想查看大量使用 UI 线程的代码的每一部分。
有没有办法在不修改大量代码的情况下绘制图表或进行某种跟踪以查看哪些方法花费的时间最长?

最佳答案

您可以做的第一件事是启用 StrictMode .这将检测在主线程上运行的非 UI、可能较长的操作。
如上所述,您可以做的第二件事是分析 CPU。您将能够看到每个线程的 Activity ,因此您可以确定在哪里运行什么。为了获得准确的读数,请勿从 Android Studio 运行它。直接从您的代码运行它。最简单的方法是使用 Debug class ,并在 Application.onCreate && 开始采样,并在应用关闭时完成它。
您可以做的第三件事是观察发送到主线程循环器的消息并评估它们。 Pierre-Yves Ricau 有一个 nice guide关于这一点,您可以适应自己的流程。
之后,您可以使用自定义方法来评估代码的关键部分,例如生成自己的跟踪。 Perfetto 使用 JSON 文件,因此您可以从您怀疑引起问题的部分打印 logcat 消息,并将这些消息解析为 perfetto trace .

关于android - 如何找出我的代码的哪些部分最常使用 UI 线程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71684346/

相关文章:

java - 使用 Traces.txt 了解 ANR 错误

Android 服务被 ANR 杀死

android - 在 com.example.widget.MyTableRow 上找不到值类型为 java.lang.String 的属性 'app:rowContentText' 的 getter

android - 选择中实现android gmail平板设计(箭头样式)

android - 如何通过android MediaPlayer播放多轨视频文件?

Android:有什么好的解决方案如何验证编辑框

android - 如何使用 Espresso 访问外部网站上的元素

android -/data/anr/traces.txt 在程序中不可访问,因为 Android N

android - 文本转语音导致大多数驱动程序和长文本出现 ANR

android - 在 android 中使用辅助功能服务获取大量 ANR