记一次ANR日志定位过程(Android)

程序猿日常

今天记一次ANR日志定位过程,大家一起学习参考!
一.触发ANR,产生ANR日志(OPPO A9)

先UI线程写个sleep(10000),运行这里时,点击屏幕或按钮触发ANR,触发ARN的原理这里不在赘述。

try {
   Thread.sleep(10000);
}catch (Exception e){
}

在这里插入图片描述
当系统出现 ANR 时,设备会自动将 ANR 日志输出到 /data/anr/ 目录下

adb shell 
cd /data/anr/
ls

在这里插入图片描述
看到ANR日志(注释:测试中发现有的手机Nova7se不能实时产生ANR日志,原因未知)

补充:
Nova7se 并不是不实时产生ANR日志是由于鸿蒙系统修改了相关机制,实测,需要多次触发ANR然后点击等待,再次触发ANR,再点击等待,循环几次操作,/data/anr中才产生了日志
在这里插入图片描述

二.分析ANR日志(OPPO A9)

由于系统原因,日志权限访问问题,通过adb bugreport导出到电脑。

adb bugreport

在这里插入图片描述
zip会导出到Download文件夹,进行解压,拿到anr日志。
在这里插入图片描述
“main” prio=5 tid=1 搜索main线程
在这里插入图片描述
可以看到anr的具体位置了,“main” prio=5 tid=1 Sleeping的线程状态可能就是TimeWaiting状态

还有其他状态如下:

“main” prio=5 tid=1 Native 线程正常状态(不一定 也可能系统服务超时导致ANR)
“main” prio=5 tid=1 Runnable 线程耗时操作
“main” prio=5 tid=1 Blocked 主线程被锁阻塞

线程状态可以参考 https://zhuanlan.zhihu.com/p/378902923

三.验证,写个while循环看下线程状态(OPPO A9)

在这里插入图片描述
(OPPO A9)记得点击下按钮触发ANR,按上面步骤操作导出ANR文件后查看,发现线程状态如下图
“main” prio=5 tid=1 Runnable 线程耗时操作
在这里插入图片描述

(Nova 7SE)同样的代码,导出ANR文件后查看发现线程状态 如下图
“main” prio=5 tid=1 Native 线程正常状态
在这里插入图片描述

tips

发现开启bugly后日志被拦截定位不到anr位置,关闭bugly就可以定位到,看看bugly做了啥😓,
难道是通过mmap映射到了他们的日志收集里去了?
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

五个木

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值