分析ANR或者系统内存崩溃的问题[转]

223 阅读1分钟

一:什么是ANR

ANR:Application Not Responding,即应用无响应

二:ANR的类型

ANR一般有三种类型:

1:**KeyDispatchTimeout(5 seconds) --**主要类型

按键或触摸事件在特定时间内无响应

2 BroadcastTimeout(10 seconds)

BroadcastReceiver在特定时间内无法处理完成

3:**ServiceTimeout(20 seconds) --**小概率类型

Service在特定的时间内无法处理完成

三:KeyDispatchTimeout

Akey or touch event was not dispatched within the specified time(按键或触摸事件在特定时间内无响应)

具体的超时时间的定义在framework下的

ActivityManagerService.java

//How long we wait until we timeout on key dispatching.

staticfinal int KEY_DISPATCHING_TIMEOUT = 5*1000

四:为什么会超时呢?

超时时间的计数一般是从按键分发给app开始。超时的原因一般有两种

(1)当前的事件没有机会得到处理(即UI线程正在处理前一个事件,没有及时的完成或者looper被某种原因阻塞住了)

(2)当前的事件正在处理,但没有及时完成

五:如何避免KeyDispatchTimeout

1 UI线程尽量只做跟UI****相关的工作

2 :耗时的工作(比如数据库操作, I/O ,连接网络或者别的有可能阻碍UI线程的操作)把它放入单独的线程处理

3 :尽量用Handler来处理UIthread和别的thread之间的交互

参考:[转]分析ANR或者系统内存崩溃的问题

下面几篇文章写的也很好,虽然我没怎么看懂,先记录下来,后面再研究

如何分析ANR问题

ANR问题分析总结

一文教你轻松搞定ANR异常捕获与分析方法

# 应用与系统稳定性第一篇---ANR问题分析的一般套路