zoukankan      html  css  js  c++  java
  • Android ANR

    ANR定义与分类

    ANR(Application Not Responding):应用程序无响应,是Android中AMS与WMS监测应用响应超时的表现;

    我们应用开发中常见的ANR主要有如下几类:

    • 按键触摸事件派发超时ANR,一般阈值为5s(设置中开启ANR弹窗,默认有事件派发才会触发弹框ANR);
    • 广播阻塞ANR,一般阈值为10s(设置中开启ANR弹窗,默认不弹框,只有log提示);
    • 服务超时ANR,一般阈值为20s(设置中开启ANR弹窗,默认不弹框,只有log提示);

    ANR的定位与分析

    当ANR发生时除过logcat可以看见的log以外我们还可以在系统指定目录下找到traces文件进行分析,发生ANR后我们可以通过如下命令得到ANR trace文件:

    adb pull /data/anr/traces.txt ./

    然后我们用txt编辑器打开,可以发现如下结构:

    //显示进程id、ANR发生时间点、ANR发生进程包名

    ----- pid 7004 at 2017-09-18 03:23:33 -----
    Cmd line: com.yunzhiyuan100.wish

    JNI: CheckJNI is on; workarounds are off; pins=2; globals=301

    
    //一些GC等object信息,通常可以忽略
    ......
    //ANR方法堆栈打印信息!重点!
    DALVIK THREADS (18):
    "main" prio=5 tid=1 Sleeping
      | group="main" sCount=1 dsCount=0 obj=0x7497dfb8 self=0x7f9d09a000
      | sysTid=19073 nice=0 cgrp=default sched=0/0 handle=0x7fa106c0a8
      | state=S schedstat=( 125271779 68162762 280 ) utm=11 stm=1 core=0 HZ=100
      | stack=0x7fe90d3000-0x7fe90d5000 stackSize=8MB
      | held mutexes=
      at java.lang.Thread.sleep!(Native method)
      - sleeping on <0x0a2ae345> (a java.lang.Object)
      at java.lang.Thread.sleep(Thread.java:1031)
      - locked <0x0a2ae345> (a java.lang.Object)
    //真正导致ANR的问题点,可以发现是onClick中有sleep导致。我们平时可以类比分析即可,这里不详细说明。
      at java.lang.Thread.sleep(Thread.java:985)
      at com.example.yanbo.myapplication.MainActivity$1.onClick(MainActivity.java:21)
      at android.view.View.performClick(View.java:4908)
      at android.view.View$PerformClick.run(View.java:20389)
      at android.os.Handler.handleCallback(Handler.java:815)
      at android.os.Handler.dispatchMessage(Handler.java:104)
      at android.os.Looper.loop(Looper.java:194)
      at android.app.ActivityThread.main(ActivityThread.java:5743)
      at java.lang.reflect.Method.invoke!(Native method)
      at java.lang.reflect.Method.invoke(Method.java:372)
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:988)
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:783)
    ......
    //省略一些不常关注堆栈打印
    ......

    OK,ANR分析结束。

  • 相关阅读:
    使用DevExpress 控件开发通用查询控件(Winform)
    SQL 排序函数
    SQL Server 消除科学计数法
    Excel VBA 的GetOpenFilename 方法
    分布式定时任务利用分布式定时任务框架xxljob实现任务动态发布
    java 同时启动多个项目
    Jooq配置与使用
    java 线上诊断工具arthas使用记录及k8s使用
    k8s脚本
    输入汉字获得拼音(VB.net)
  • 原文地址:https://www.cnblogs.com/linghu-java/p/7655068.html
Copyright © 2011-2022 走看看