浅谈ANR及如何分析解决ANR

(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,查看并分析

 

 

参考原文:http://blog.csdn.net/tjy1985/article/details/6777346

参考原文:http://blog.csdn.net/tjy1985/article/details/6777355 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值