Android 应用程序无响应定位ANR原因

废话不多说,直接上方案:

第一步:

执行adb命令

adb bugreport /Users/mac/Desktop/anr

解压后FS/data/anr下就会有相关anr文件

/Users/mac/Desktop/anr 是电脑存储文件的路径,可以随便定义,这个没有影响。我的电脑是mac,如果是windows,可以将路径修改为E:\xxx\xxxx,同样可以随便定义。

第二步:

解压后,目录结构大致是这样。框起来的部分就是最近出发ANR的日志,当然如果应用进程一样,其他时间段的也可以看看。

第三步:

以anr_2023-12-01-09-59-25-223这个日志为例,查看具体原因。

头部第一步部分标明了应用进程、pid、uid、应用包名、版本号、ANR类型(触摸事件在5s内无响应)Waited 5001ms for KeyEvent(action=DOWN))。包名也正好是自己的应用包名,直接全局查找报名相关的代码。

定位具体原因,代码执行解压出现耗时操作,修改代码逻辑。

---------------------------------------------------完结撒花---------------------------------------------------

相关推荐
墨狂之逸才1 天前
Android TV WebView 遥控器按键处理:从全透传到白名单
android
plainGeekDev1 天前
MVC 写法 → MVVM
android·java·kotlin
恋猫de小郭2 天前
Flutter Patchwork,不用 Fork 改依赖包源码的第三方工具
android·前端·flutter
三少爷的鞋2 天前
“结构化”这个词,本质上就是——把混乱的东西变成有组织、有规则、有边界的东西
android
方白羽2 天前
Android Gradle 缓存与文件目录深度解析
android·gradle·android studio
曲幽2 天前
Termux里的二进制和脚本,到底怎么运行才不踩坑?Termux-service 保活妙招!
android·termux·nohup·services·wake-lock
plainGeekDev2 天前
单例模式 → object 声明
android·java·kotlin
程序员陆业聪2 天前
读者点单·03|Compose 与传统 View 混用的 12 个真实坑
android
程序员陆业聪2 天前
读者点单·02|Android 启动优化实战:Trace 抓取→Application 编排→冷启动全流程拆解
android
Coffeeee2 天前
帮你快速理解AI Agent之我想招个Android实习生
android·人工智能·agent