Anr发生时的log分析

本文详细介绍了Android ANR(Application Not Responding)的三种类型:KeyDispatchTimeout、BroadcastTimeout和ServiceTimeout,分析了ANR产生的原因,包括主线程阻塞、其他应用进程影响和IO等待。同时,讲解了ANR发生时的日志分析方法,通过logcat和/data/anr/trace.txt文件定位问题,并提供了关键的日志线索和线程状态信息。
摘要由CSDN通过智能技术生成

(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.输入操作/特定操作:输入操作指按键、触屏等操作,特定操作指广播、服务中执行耗时方法等。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dl6655

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值