ANR分析

ANR类型

ANR一般有三种类型:

  1. KeyDispatchTimeout(5 seconds) --主要类型按键或触摸事件在特定时间内无响应

  2. BroadcastTimeout(10 seconds) --BroadcastReceiver在特定时间内无法处理完成

  3. ServiceTimeout(20 seconds) --小概率类型 Service在特定的时间内无法处理完成

获取trace文件
  • cat /data/anr/traces.txt > /mnt/sdcard/tt.txt
基本信息解析(Log信息)

从LOG可以看出ANR的类型,CPU的使用情况,如果CPU使用量接近100%,说明当前设备很忙,有可能是CPU饥饿导致了ANR
如果CPU使用量很少,说明主线程被BLOCK了
如果IOwait很高,说明ANR有可能是主线程在进行I/O操作造成的
其他进程间接引起,例如:
当前应用进程进行进程间通信请求其他进程,其他进程的操作长时间没有反馈;
其他进程的CPU占用率高,使得当前应用进程无法抢占到CPU时间片;

  • 仔细查看ANR的成因(iowait?block?memoryleak?)

  • 01-15 16:49:02.433 E/ActivityManager( 2466): Load: 0.6 / 0.61 / 0.42
    翻译:5分钟,10分钟&#x

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值