AndroidL ANR分析整理

ANR简介

一:什么是ANR

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

 

二:ANR的类型

ANR一般有三种类型:

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

按键或触摸事件在特定时间内无响应,超时时间为ActivityManagerService.java中的KEY_DISPATCHING_TIMEOUT

2BroadcastTimeout(10 seconds)

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

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

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

 

三:ANR日志

ANR 日志在 /data/anr 目录下

 

四:为什么会超时呢?

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

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

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

 

五:如何避免KeyDispatchTimeout

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

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

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

 

六:UI线程

说了那么多的UI线程,那么哪些属于UI线程呢?

UI线程主要包括如下:

1:Activity:onCreate(), onResume(), onDestroy(), onKeyDown(),onClick(),etc

2:AsyncTask: onPreExecute(), onProgressUpdate(), onPostExecute(),onCancel,etc

3:Mainthread handler: handleMessage(), post*(runnable r), etc

4:other

 

七:关键字

1:”anr” –注意后面的空格,可以省去好多无用信息

2:KeyDispatchTimeout


八:ANR发生情况

1:死锁
2:CPU使用量接近100%
3:主线程中进行网络操作,读写数据库,死循环等

你可能感兴趣的:(AndroidL ANR分析整理)