Android异常之应用已停止运行的日志分析

Android  2020年6月8日 am9:00发布4年前 (2020)更新 91es.com站长
52 0 0

文章之前写过,重新整理一下。

为什么会有应用已停止运行?

运行时出现了未捕获的异常,导致程序无法正常运行。

如下面,主线程(main)出现致命异常(fatal exception)导致程序无法正常运行。

 # main主线程,fatal exception 致命异常
 AndroidRuntime: FATAL EXCEPTION: main
 AndroidRuntime: Process: com.la.allwater, PID: 4553
 AndroidRuntime: java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.ContentResolver android.content.Context.getContentResolver()' on a null object reference
 AndroidRuntime:        at com.la.allwater.HomeMainActivity$1.onClick(HomeMainActivity.java:40)
 AndroidRuntime:        at android.view.View.performClick(View.java:6609)
 AndroidRuntime:        at android.view.View.performClickInternal(View.java:6582)
 AndroidRuntime:        at android.view.View.access$3100(View.java:780)
 AndroidRuntime:        at android.view.View$PerformClick.run(View.java:26094)
 AndroidRuntime:        at android.os.Handler.handleCallback(Handler.java:873)
 AndroidRuntime:        at android.os.Handler.dispatchMessage(Handler.java:99)
 AndroidRuntime:        at android.os.Looper.loop(Looper.java:193)
 AndroidRuntime:        at android.app.ActivityThread.main(ActivityThread.java:6702)
 AndroidRuntime:        at java.lang.reflect.Method.invoke(Native Method)
 AndroidRuntime:        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
 AndroidRuntime:        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:994)

如何定位问题了

一般这样的问题寻找关键字AndroidRuntime或者FATAL或者EXCEPTION

这三个关键字各有优点,个人比较喜欢使用fatal来定位更快一些。

解决问题

报错可以,但不能影响整个应用,因此在一些未知情况下可以使用如下方式做一定的处理。

新增判断条件

既然不支持是否为null,因此在使用前进行null判断,不为null才执行后续判断

                if (null != context) {
                   context.getContentResolver();
               }
防患未来

捕获可能存在异常的代码块。异常正常打印,不会影响整个影藏。

                try {
                    context.getContentResolver();
                } catch (Exception e) {
                    e.printStackTrace();
                }

 历史上的今天

  1. 2021: 樊小纯:借我(0条评论)
版权声明 1、 本站名称: 91易搜
2、 本站网址: 91es.com3xcn.com
3、 本站内容: 部分来源于网络,仅供学习和参考,若侵权请留言
3、 本站申明: 个人流水账日记,内容并不保证有效

暂无评论

暂无评论...

随机推荐

ANR原因以及解决方法

 一. ANR (Application Not Responding)的定义?在Android上,应用程序如果没有响应,系统会向用户显示一个对话框,这个对话框称作应用程序无响应(ANR:Application Not Responding)对话框。用户可以选择等待或者强制关闭。一个...

Android WindowManager弹窗容易出现的问题

WindowManager弹窗提示时需要注意下,比如系统应用和非系统应用权限的不同、Android不同版本的权限申请不同等,下面是我在应用中出现的问题,因此整理一下。问题一:没有设置android.permission.SYSTEM_ALERT_WINDOW出现异常提示Unable to a...

Android Studio将lib项目打包成jar和aar

jar包和aar包的区别jar包只包含class文件,不包含资源文件。aar包包含class文件和资源文件。aar生成及引用Android Studio编译lib库会在build/outputs/aar目录生成aar,有两个一个debug一个release。(至于这两个区别,我没有深入...

Activity的启动模式分析

以下是主要的测试代码package com.hi.hello;import android.app.Activity;import android.content.Intent;import android.os.Bundle;import android.util.Log;impor...

萧乾:吆喝

一位二十年代在北京作寓公的英国诗人奥斯伯特. 斯提维尔写过一篇《北京的声与色》,把当时走街串巷的小贩用以招徕顾客而做出的种种音响形容成街头管弦乐队,并还分别列举了哪是管乐、弦乐和打击乐器。他特别喜欢听串街的理发师(“剃头的”) 手里那把钳形铁铉。用铁板从中间一抽,就会呲啦一声发出带点颤巍的金属声响,...

[摘]Java垃圾回收机制(GC)详解

简介:垃圾回收GC(Garbage Collection)是Java语言的核心技术之一,之前我们曾专门探讨过Java 7新增的垃圾回收器G1的新特性,但在JVM的内部运行机制上看,Java的垃圾回收原理与机制并未改变。垃圾收集的目的在于清除不再使用的对象。GC通过确定对象是否被活动对象引用来确定...