(1)什么是ANR
ANR:Application Not Responding,即应用无响应
(2)ANR的类型
ANR一般有三种类型:
a:KeyDispatchTimeout(5 seconds) --主要类型,按键或触摸事件在特定时间内无响应。A key 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
b:BroadcastTimeout(10 seconds),BroadcastReceiver在特定时间内无法处理完成
c:ServiceTimeout(20 seconds) --小概率类型,Service在特定的时间内无法处理完成
(3)为什么会超时呢?
超时时间的计数一般是从按键分发给app开始。超时的原因一般有两种:
a,当前的事件没有机会得到处理(即UI线程正在处理前一个事件,没有及时的完成或者looper被某种原因阻塞住了)
b,当前的事件正在处理,但没有及时完成
(4)如何避免KeyDispatchTimeout
a,UI线程尽量只做跟UI相关的工作
b,耗时的工作(比如数据库操作,I/O,连接网络或者别的有可能阻碍UI线程的操作)把它放入单独的线程处理
c,尽量用Handler来处理UIthread和别的thread之间的交互
(5)UI线程
说了那么多的UI线程,那么哪些属于UI线程呢?UI线程主要包括如下:
a,Activity:onCreate(), onResume(), onDestroy(), onKeyDown(), onClick(),etc
b,AsyncTask: onPreExecute(), onProgressUpdate(), onPostExecute(), onCancel,etc
c,Mainthread handler: handleMessage(), post*(runnable r), etc
(6)如何去分析ANR
首先从LOG可以看出ANR的类型,CPU的使用情况,如果CPU使用量接近100%,说明当前设备很忙,有可能是CPU饥饿导致了ANR;如果CPU使用量很少,说明主线程被BLOCK了;如果IOwait很高,说明ANR有可能是主线程在进行I/O操作造成的。除了看LOG,解决ANR有时还得需要trace.txt文件,如何获取呢?可以用如下命令获取
a,$chmod 777 /data/anr
b,$rm /data/anr/traces.txt
c,重新操作ANR产生
d,adbpull data/anr/traces.txt ./mytraces.txt,查看并分析
(7)如果根据程序的ANR LOG定位问题代码
发生ANR的时候,会Wrote stack traces to '/data/anr/traces.txt',拷贝出这个txt文件分析。并从问题LOG中定位到为题代码,参考工具是addr2line,方法是http://blog.csdn.net/andy_android/article/details/43985281。
参考原文:http://blog.csdn.net/tjy1985/article/details/6777346
参考原文:http://blog.csdn.net/tjy1985/article/details/6777355
=========================如何分析系统或者应用卡顿问题=======================
(1)用free命令查看系统内存占用大概情况
(2)adb shell dumpsys meminfo 查看系统应用及APP的内存占用情况,判断是否有内存泄漏。具体用法参见https://blog.51cto.com/ticktick/1346785
(3)分析关键文件和关键字段
如SYS_ANDROID_LOG,和如下提示CPU占用率过高是由于某个地图应用出错