ANR问题了解新思路

2023-05-16

众所周知,ANR问题一般不太容易解决。它是一种比较综合性的问题。往往涉及系统事件分发逻辑,ANR产生机制,BINDER机制,线程同步,CPU和内存使用等各方面。意思就是说,要分析ANR,你需要的知识非常多。
也就因此,很多人看着ANR问题感觉无从下手,日志中的很多说法都很抽象。
既然如此,我们在了解一些基础知识的基础上,再自己去写一下anr是不是可以??
手动写出的“问题代码”如下:

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        //Debug.startMethodTracing();
        Trace.beginSection("zhangkai");
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTextView = findViewById(R.id.textView);
        Log.d("kaijun", "onCreate: ");
        mTextView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Log.d("kaijun", "onClick: -----");

                Intent intent = new Intent();
                intent.setComponent(new ComponentName("com.kaijun.compareapplication","com.kaijun.compareapplication.MyService"));
                bindService(intent, mSc, Context.BIND_AUTO_CREATE);
            }
        });

        waitForTenminute();

        Trace.endSection();

        //Debug.stopMethodTracing();
    }

waitForTenminute()的具体实现:

    public void waitForTenminute() {
        try {
            Thread.sleep(10000);
            Log.d("kaijun", "waitForTenminute: ----------------");
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

我们要模拟的场景如下:
输入事件超时。
也就是说,我在activity的onCreate方法中执行耗时操作。执行时间10s,如果在执行的过程中,我们有事件输入的话,由于主线程正在执行耗时操作,也就无法响应我们的操作。如果执行无响应超过5s,也就报出anr了。
此处需要注意一点:
如果按照当前代码运行,点击进入app后,如果我们不对手机进行任何操作,则主线程执行完耗时操作后就正常进入activity,并不会报出超时。只有在此过程中我们输入事件,才会直接导致系统弹出anr弹框。
总结:有anr不一定弹框。

按照我们的操作:

  • 先进入activity,此时界面白屏,因为activity的onCreate并未执行完毕,我们只能看到一个白框
  • 然后,点击返回键,等待
  • 5s后弹出错误弹框
    日志:
04-19 19:19:42.724  1118  4309 I ActivityManager: Done dumping
04-19 19:19:42.724  1118  4309 I AnrManager: dumpStackTraces end!
04-19 19:19:42.776  1118  4309 I AnrManager: ANR in com.kaijun.binderclientapp (com.kaijun.binderclientapp/.MainActivity), time=369867387
04-19 19:19:42.776  1118  4309 I AnrManager: Reason: Input dispatching timed out (ActivityRecord{4ced468 u0 com.kaijun.binderclientapp/.MainActivity t255} does not have a focused window)
04-19 19:19:42.776  1118  4309 I AnrManager: Load: 17.45 / 15.63 / 15.33
04-19 19:19:42.776  1118  4309 I AnrManager: Android time :[2021-04-19 19:19:42.72] [369876.625]

从日志来看:
AnrManager: Reason: Input dispatching timed out (ActivityRecord{4ced468 u0 com.kaijun.binderclientapp/.MainActivity t255} does not have a focused window)

然后我们看/data/anr/目录下的trace文件。打开文件后直奔tid=1的线程,也就是主线程:

"main" prio=5 tid=1 Sleeping
  | group="main" sCount=1 dsCount=0 flags=1 obj=0x70e44300 self=0xa8b04610
  | sysTid=20309 nice=0 cgrp=default sched=0/0 handle=0xb18f6470
  | state=S schedstat=( 2986803784 560166676 1224 ) utm=234 stm=64 core=1 HZ=100
  | stack=0xbe073000-0xbe075000 stackSize=8192KB
  | held mutexes=
  at java.lang.Thread.sleep(Native method)
  - sleeping on <0x0139d315> (a java.lang.Object)
  at java.lang.Thread.sleep(Thread.java:442)
  - locked <0x0139d315> (a java.lang.Object)
  at java.lang.Thread.sleep(Thread.java:358)
  at com.kaijun.binderclientapp.MainActivity.waitForTenminute(MainActivity.java:107)
  at com.kaijun.binderclientapp.MainActivity.onCreate(MainActivity.java:64)
  at android.app.Activity.performCreate(Activity.java:8000)
  at android.app.Activity.performCreate(Activity.java:7984)
  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1309)
  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3464)

可以看到,主线程处于sleep状态。跟我们的代码中的Thread.sleep一致。
通过这个问题,仔细想一下anr问题的分析思路是不是更清晰了一些?

另外,多关注日志。通过eventlog我们可以看一下输入事件响应超时类问题的超时时间:

//点击back键
04-19 19:50:20.665  1118  2302 I sysui_multi_action: [757,803,799,key_back_down,802,1]
//报出anr
04-19 19:50:25.467  1118 10558 I am_anr  : [0,10425,com.kaijun.binderclientapp,550027078,Input dispatching timed out (ActivityRecord{e82260b u0 com.kaijun.binderclientapp/.MainActivity t263} does not have a focused window)]

并且日志中可以看到对应的trace文件在那个目录,具体是哪个文件:

04-19 19:50:26.178  1118 10558 I ActivityManager: Dumping to /data/anr/anr_2021-04-19-19-50-26-177
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

ANR问题了解新思路 的相关文章

随机推荐

  • batch norm、relu、dropout 等的相对顺序和BN、dropout的几个问题和思考

    总结 xff1a BN和dropout一般不同时使用 xff0c 如果一定要同时使用 xff0c 可以将dropout放置于BN后面 1 batch norm relu dropout 等的相对顺序 Ordering of batch no
  • 推荐系统之ESMM算法精读和实战

    目录 一 背景 二 ESMM模型 2 1 ESMM 模型结构 2 2 ESMM模型特点 2 3 ESMM模型适用场景 三 实验效果 lt
  • 远程桌面连接 提示用户名密码错误的解决办法

    提示 用户名或者密码错误 xff0c 有两种可能 xff1a 1是 用户名 密码可能输入错误 2是 可能你这个用户名暂不支持远程访问 首先解决用户名 密码的问题 xff1a 计算机的命名规则为 计算机 43 账户 的形式 如果您的账户不是A
  • 金融时间序列模型整理

    GARCH模型 https www math pku edu cn teachers lidf course fts ftsnotes html ftsnotes fts garch html 金融时间序列入门 完结篇 ARCH GARCH
  • 工具学习——ubuntu轻量桌面对比

    因为最近要做一些ubuntu上的开发 xff0c 然后使用ssh问题是经常会出现中断 xff0c 虽然可以使用等tmux方法来挂起进程 xff0c 但是感觉不如界面方便 xff0c 然后现在问题来了 xff0c 我的ubuntu服务器是一个
  • JPA自定义VO接受返回结果集(unwrap)

    JPA跟mybitis比较 xff0c 简单的业务搜索是方便的 xff0c 但是设计到复杂的SQL搜索时 xff0c 我们需要自定义SQL 1 64 Query直接写SQL 缺点是无法动态的组装条件 2 JPA的Specification对
  • 快速排序详解-java实现

    一 快速排序 整体过程 xff1a 1 先从数组中找一个数作为基准数 xff0c 2 进行分区 xff0c 分区时大于这个数得全部放到右边 xff0c 小于这个数得全部放到左边 xff0c 等于这个数得全部放到中间 xff08 核心过程 x
  • 应届生应该如何准备校招

    大家好 xff0c 我是羽峰 xff0c 今天要和大家分享的是应届生应该如何准备校招 xff0c 希望该文章对一些今年要找工作的朋友有一些帮助 还是老话 xff0c 我是羽峰 xff0c 希望我所分享的文章能为您及更多的朋友带来帮助 欢迎转
  • mysql提示Can‘t connect to MySQL server on localhost (10061)解决方法

    本文mysql的安装环境为win10 64位 xff0c mysql版本为MySQL5 7 我遇到的问题是 电脑原先安装过mysql xff0c 卸载不干净 xff0c 重装默认以前的用户名和密码 xff0c 然鹅 我不知道用户名和密码 以
  • 哈希表与一致性哈希表

    哈希表定义 散列表 xff08 Hash table xff0c 也叫哈希表 xff09 xff0c 是根据关键码值 Key value 而直接进行访问的数据结构 它通过把关键码映射到表中一个位置来访问记录 xff0c 以加快查找的速度 这
  • 【AI欣赏】将火影忍者推向新高度:StableDiffusion的神奇效果

    AI欣赏 将火影忍者推向新高度 xff1a StableDiffusion的神奇效果 x1f525 你是否曾经梦想过将自己的绘画水平提升到一个新的高度 xff0c 让你的艺术作品能够轻松地与官方制作相媲美呢 xff1f StableDiff
  • 2023-03-06 debian11 最小安装记录

    1 镜像准备 xff0c 根据个人需求下载debian 版本 Debian 获取 Debian 2 上传到VSAN 内容库 我这边是在vm里面安装的 xff0c 就直接上传到内容库备用 xff08 根据个人需求存放 xff09 3 分配虚拟
  • Vue 项目启动报错:http://eslint.org/docs/rules/no-unused-vars

    Vue项目启动时报 xff1a http eslint org docs rules no unused vars 39 vm 39 is assigned a value but never used src navigation nav
  • Android解决相机预览拉伸问题

    拉伸的原因 1 主要是由于surfaceview的尺寸和 相机预览尺寸不一致造成的 64 Override span class token keyword public span span class token keyword void
  • Linux技巧

    0001 修改主机名 bjchenxu vi etc sysconfig network xff0c 修改HOSTNAME一行为 34 HOSTNAME 61 主机名 34 没有这行 xff1f 那就添加这一行吧 xff0c 然后运行命令
  • 8.消抖技术

    简介 开关的金属触点在断开闭合的过程中产生了多个信号 xff0c 消抖就是保证只有一个信号起到作用 这样的小抖动不像快脉冲一样造成市电上的其他设备出现故障 但是会导致模拟电路快速翻转的数字信号电路出现故障 便宜的电脑键盘通常使用导电橡胶制成
  • 1.7-1.8动态库加载失败的原因和解决办法

    目录 1 动态库和静态库的原理 2 动态库加载失败的原因 3 解决方法 3 1 DT RPATH段 3 2将libcalc so的路径加入到环境变量LD LIBRARY PATH中 3 3将libcalc so的路径加入到 etc ld s
  • Spring中Bean创建完成后执行指定代码的几种实现方式

    Spring中Bean创建完成后执行指定代码的几种实现方式 1 实现ApplicationListener接口2 实现InitializingBean接口3 使用 64 PostConstruct注解 在实际开发中经常会遇到在spring容
  • archlinux fcitx5 在浏览器中不能使用中文输入法

    archlinux系统升级后 xff0c fcitx5 在浏览器中不能使用中文输入法 xff0c 解决办法 xff1a 编辑 etc environment 并添加以下几行 xff0c 然后重新登录 1 xff1a GTK IM MODUL
  • ANR问题了解新思路

    众所周知 xff0c ANR问题一般不太容易解决 它是一种比较综合性的问题 往往涉及系统事件分发逻辑 xff0c ANR产生机制 xff0c BINDER机制 xff0c 线程同步 xff0c CPU和内存使用等各方面 意思就是说 xff0