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))。包名也正好是自己的应用包名,直接全局查找报名相关的代码。

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

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

相关推荐
阿达C2 小时前
MySQL常用函数详解及SQL代码示例
android·sql·mysql
缘来的精彩4 小时前
Android Studio 中实现方法和参数显示一行
android·ide·android studio
二七有头发4 小时前
从零开始:Android Studio开发购物车(第二个实战项目)
android·ide·android studio
我命由我123454 小时前
MQTT - Android MQTT 编码实战(MQTT 客户端创建、MQTT 客户端事件、MQTT 客户端连接配置、MQTT 客户端主题)
android·java·java-ee·android studio·android jetpack·android-studio·android runtime
奔跑吧 android5 小时前
【android bluetooth 协议分析 06】【l2cap详解 11】【l2cap连接超时处理逻辑介绍】
android·bluetooth·l2cap·gd·aosp13
百锦再11 小时前
Android Studio开发中Application和Activity生命周期详解
android·java·ide·app·gradle·android studio·studio
移动开发者1号12 小时前
Android现代进度条替代方案
android·app
万户猴12 小时前
【Android蓝牙开发实战-11】蓝牙BLE多连接机制全解析1
android·蓝牙
RichardLai8812 小时前
[Flutter 基础] - Flutter基础组件 - Icon
android·flutter
前行的小黑炭12 小时前
Android LiveData源码分析:为什么他刷新数据比Handler好,能更节省资源,解决内存泄漏的隐患;
android·kotlin·android jetpack