当前位置:   article > 正文

Anr发生时的log分析_anr log分析

anr log分析

(1)Anr类型

     ANR一般有三种类型:

  1. KeyDispatchTimeout(5 seconds) –主要类型按键或触摸事件在特定时间内无响应 (No response to an input event (such as key press or screen touch events) within 5 seconds.)

  2. BroadcastTimeout(10 seconds) –BroadcastReceiver在特定时间内无法处理完成 (A BroadcastReceiver hasn’t finished executing within 10 seconds.)

  3. ServiceTimeout(20 seconds) –小概率类型 Service在特定的时间内无法处理完成  (Service timeout 20s)

 

(2)ANR产生的原因

    一、超时的原因一般有两种(超时计时时间点:超时时间计时,一般是从按键分发给app开始):

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

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

 

   二、需要满足的条件:

        1.主线程:只有应用的主线程响应超时才会导致ANR

        2.超时时间(Timeout):导致ANR的原因不同,系统限定的时间也不同,但只要超过时间上限,系统就会发出Signal 3,产生ANR

        3.输入操作/特定操作:输入操作指按键、触屏等操作,特定操作指广播、服务中执行耗时方法等。

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/235657
推荐阅读
相关标签
  

闽ICP备14008679号