ANR

1、ANR排错一般有三种类型

  • KeyDispatchTimeout(5 seconds) --主要是类型按键或触摸事件在特定时间内无响应
  • BroadcastTimeout(10 seconds) --BroadcastReceiver在特定时间内无法处理完成
  • ServiceTimeout(20 secends) --小概率事件 Service在特定的时间内无法处理完成

2、哪些操作会导致ANR 在主线程执行以下操作:

  • 高耗时的操作,如图像变换
  • 磁盘读写,数据库读写操作
  • 大量的创建新对象

3、如何避免

  • UI线程尽量只做跟UI相关的工作
  • 耗时的操作(比如数据库操作,I/O,连接网络或者别的有可能阻塞UI线程的操作)把它放在单独的线程处理
  • 尽量用Handler来处理UIThread和别的Thread之间的交互

4、解决的逻辑

  • 使用AsyncTask
  • 在doInBackground()方法中执行耗时操作
  • 在onPostExecuted()更新UI
  • 使用Handler实现异步任务
  • 在子线程中处理耗时操作
  • 处理完成之后,通过handler.sendMessage()传递处理结果
  • 在handler的handleMessage()方法中更新UI
  • 或者使用handler.post()方法将消息放到Looper中

5、如何排查

  • 首先分析log
  • 从trace.txt文件查看调用stack,adb pull data/anr/traces.txt ./mytraces.txt
  • 看代码
  • 仔细查看ANR的成因(iowait?block?memoryleak?)

6、监测ANR的Watchdog

最近出来一个叫LeakCanary

#FC(Force Close) ##什么时候会出现

Error
OOM,内存溢出
StackOverFlowError
Runtime,比如说空指针异常
##解决的办法

注意内存的使用和管理
使用Thread.UncaughtExceptionHandler接口

文章来源:

https://github.com/francistao/LearningNotes/blob/master/Part1/Android/ANR%E9%97%AE%E9%A2%98.md

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值