首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >RuntimeException在安卓系统上引发ANR

RuntimeException在安卓系统上引发ANR
EN

Stack Overflow用户
提问于 2021-08-04 06:09:02
回答 1查看 56关注 0票数 1

我的Android应用程序有问题。当我抛出RuntimeException时,它会导致ANR而不是崩溃。

例如,我有这样的代码:

代码语言:javascript
复制
button.setOnClickListener {
    throw RuntimeException("Test crash")
}

当我点击这个按钮时,应用程序冻结了一段时间,然后显示有关ANR的警报。

我读过类似的问题,标题在这里:RuntimeException causes ANR instead of crash in android

但我想不出怎么解决它。我检查了我能做的一切:没有附加UncaughtExceptionHandler-s,我没有使用过时的google-play-services库。我应该在哪里查找问题的原因?

有趣的是,单击此按钮后,我可以在logcat中看到堆栈跟踪:

代码语言:javascript
复制
2021-08-04 09:05:39.464 8764-8764/wa.testapp E/AndroidRuntime: FATAL EXCEPTION: main
    Process: wa.testapp, PID: 8764
    java.lang.RuntimeException: Test crash
        at com.example.testapp.ui.main.FragmentMain.onViewCreated$lambda-7(FragmentMain.kt:102)
        at com.example.testapp.ui.main.FragmentMain.$r8$lambda$agRVJ2mByrrRLVPpioFH6VVBf9s(Unknown Source:0)
        at com.example.testapp.ui.main.FragmentMain$$ExternalSyntheticLambda8.onClick(Unknown Source:0)
        at android.view.View.performClick(View.java:7448)
        at com.google.android.material.button.MaterialButton.performClick(MaterialButton.java:1119)
        at android.view.View.performClickInternal(View.java:7425)
        at android.view.View.access$3600(View.java:810)
        at android.view.View$PerformClick.run(View.java:28305)
        at android.os.Handler.handleCallback(Handler.java:938)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:223)
        at android.app.ActivityThread.main(ActivityThread.java:7656)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
2021-08-04 09:05:39.467 8764-8764/wa.testapp E/a: Exception:
    message: Test crash
    localized message: Test crash
    stack trace:
    java.lang.RuntimeException: Test crash
        at com.example.testapp.ui.main.FragmentMain.onViewCreated$lambda-7(FragmentMain.kt:102)
        at com.example.testapp.ui.main.FragmentMain.$r8$lambda$agRVJ2mByrrRLVPpioFH6VVBf9s(Unknown Source:0)
        at com.example.testapp.ui.main.FragmentMain$$ExternalSyntheticLambda8.onClick(Unknown Source:0)
        at android.view.View.performClick(View.java:7448)
        at com.google.android.material.button.MaterialButton.performClick(MaterialButton.java:1119)
        at android.view.View.performClickInternal(View.java:7425)
        at android.view.View.access$3600(View.java:810)
        at android.view.View$PerformClick.run(View.java:28305)
        at android.os.Handler.handleCallback(Handler.java:938)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:223)
        at android.app.ActivityThread.main(ActivityThread.java:7656)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-08-04 07:25:22

我找到了这种行为的原因。原因是com.smartlook.recording:app:1.1.2-native依赖。从项目中删除该库后,一切正常。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68646196

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档