九、BadTokenException:
Exception 在Android 中经常会遇到,那么遇到异常我们该如何解决,本文将举例解决部分Android看法中遇到的异常。
一、NullPointerException 空指针
==========================
NullPointerException在开发中经常会碰到,比如引用的对象为空,数组为空等等都会引起空指针异常,如不及时处理,就会导致 应用Crash。
1. 数组 NullPointerException
不能向一个null数组元素赋值,获取长度,否则报
NullPointerException: Attempt to write to null array和
NullPointerException Attempt to get length of null array,以下代码会引起上面两种空指针异常。
2. 数组NullPointerException 代码举例
public static void ArrayNullPointer() { /** * 数组空指针 NullPointerException * * 1.获取null数组长度 * 2.为null 数组元素复制 * */ int[] array = null; // 1. NullPointerException: Attempt to get length of null array int length = array.length; // 2. NullPointerException: Attempt to write to null array array[0] = 1; }
NullPointerException 代码举例
3. 数组NullPointerException Log 举例
- Log 信息如下
获取 空数组长度导致的 NullPointerException 如下:
12-27 17:17:44.627 8839 8839 E AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to get length of null array 12-27 17:17:44.627 8839 8839 E AndroidRuntime: at com.programandroid.Exception.NullPointerException.ArrayNullPointer //产生空指针代码行 (NullPointerException.java:32)
4. Log 分析如下
数组NullPointerException
空数组无法获取下标内容,如果获取则会导致NullPointerException
12-27 17:23:24.168 11649 11649 E AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to write to null array 12-27 17:23:24.168 11649 11649 E AndroidRuntime: at com.programandroid.Exception.NullPointerException.ArrayNullPointer(NullPointerException.java:34) 12-27 17:23:24.168 11649 11649 E AndroidRuntime: at com.programandroid.Exception.ExceptionActivity.NullPointerException(ExceptionActivity.java:37)
5. Object 对象 NullPointerException
对象空指针,这个是常见的空指针,主要是因为引用一个null 对象,进而导致空指针,常报以下错误
Attempt to invoke a virtual method on a null object reference,以下代码可能会引起空指针异常。
6. object 对象 NullPointerException 代码举例
简单代码举例如下:
public static void ListNullPointer() { ArrayList<String> mArrayList = null; mArrayList.size(); }
Object 对象 NullPointerException
7. object 对象 NullPointerException log 举例
- Log 信息如下:
12-27 17:28:22.565 12725 12725 E AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to invoke a virtual method on a null object reference 12-27 17:28:22.565 12725 12725 E AndroidRuntime: at com.programandroid.Exception.NullPointerException.ListNullPointer(NullPointerException.java:45) 12-27 17:28:22.565 12725 12725 E AndroidRuntime: at com.programandroid.Exception.ExceptionActivity.NullPointerException(ExceptionActivity.java:37)
8. object 对象 NullPointerException Log 分析如下:
Object NullPointerException
9. NullPointerException 解决方案
-
1.使用时多注意判断对象是否为空
-
规避空指针举例如下:
public static void ListNullPointer() { ArrayList<String> mArrayList = null; if (mArrayList != null) { mArrayList.size(); } }
使用对象是,最好判断对象是否为空
- 2.使用
try-catch将抛出的异常抓住
try-catch 可以抓住抛出的异常,使应用程序不崩溃,但是,这个不是从根本上解决问题,会引起一些莫名其妙的问题。
public static void ListNullPointer() { try { ArrayList<String> mArrayList = null; mArrayList.size(); } catch (Exception e) { // TODO: handle exception } }
try-catch 代码异常,防止app crash
二、 ClassCastException 类型转换异常
============================
ClassCastException 类型转换异常:
此异常发生在类型转换时,并且在编译期间,编译器不会提示报错,但是当运行时,如果存在此异常,可能会导致app崩溃 crash。
比如当父类强制转换为子类时,ClassCastException 就会发生
1. 以下代码 会引起 ClassCastException
请勿 父类强制转换为子类,否则就会发生ClassCastException异常。
public void ClassCastExample() { Fruit banana = new Fruit(); /** * ClassCastException * * 1. 此处强制转换,会导致 app 编译没问题,运行挂掉, Caused by: * java.lang.ClassCastException: * com.programandroid.Exception.ExceptionActivityApple * */ Apple apple = (Apple) banana; } / * ClassCastException * * 2. 此处强转回导致app crash return (Apple) banana; * */ public Apple isRight() { Fruit banana = new Fruit(); return (Apple) banana; } class Fruit { public Fruit() { } } class Apple extends Fruit { public Apple() { } }
ClassCastException 类型转换异常举例
2. ClassCastException Log 举例
ClassCastException通常会打印以下类似信息
Caused by: java.lang.ClassCastException: com.programandroid.Exception.ExceptionActivityApple
3. ClassCastException Log 分析
ClassCastException log 分析
4. ClassCastException 解决方案
使用try-catch抓住异常,或者从代码上解决根本问题。
使用 try-catch抓住 ClassCastException异常
5. Android 手机 Settings ClassCastException 解决方案
举例是为了更好的解决开发中的异常。比如在开发中,使用 monkey 测试Settings模块时,报出的 ClassCastException,Settings代码比较多,一时也无法看完,此时,try-catch 也是一种不错的选择。
比如monkey测试某平台代码时,报出以下异常
- log 信息如下:
FATAL EXCEPTION: ApplicationsState.Loader 01-05 03:36:56.101 6304 6941 E AndroidRuntime: Process: com.android.settings, PID: 6304 01-05 03:36:56.101 6304 6941 E AndroidRuntime: java.lang.ClassCastException: com.android.settings.datausage.AppStateDataUsageBridgeAppRow 01-05 03:36:56.101 6304 6941 E AndroidRuntime: at com.android.settings.applications.AppStateNotificationBridge$3.filterApp(AppStateNotificationBridge.java:110)
6. Settings ClassCastException Log分析
Settings ClassCastException Log1
Settings ClassCastException Log2
7. Setting crash ClassCastException 解决方案:
try-catch 异常报错的地方
try-catch 异常报错的地方
try-catch 异常报错的地方
三、IndexOutOfBoundsException 下标越界异常
==================================
List 在开发中经常会被用的,那么错误的使用下标,将会导致IndexOutOfBoundsException 越界异常。以下代码就会引起IndexOutOfBoundsException异常
1. IndexOutOfBoundsException 代码举例
IndexOutOfBoundsException 异常举例
2. IndexOutOfBoundsException Log举例
- Log 信息如下:
12-27 17:41:24.231 16891 16891 E AndroidRuntime: Caused by: java.lang.IndexOutOfBoundsException: Index: 0, Size: 0 12-27 17:41:24.231 16891 16891 E AndroidRuntime: at java.util.ArrayList.get(ArrayList.java:411) 12-27 17:41:24.231 16891 16891 E AndroidRuntime: at com.programandroid.Exception.IndexOutOfBoundsException.isAppOnRecent(IndexOutOfBoundsException.java:40) 12-27 17:41:24.231 16891 16891 E AndroidRuntime: at com.programandroid.Exception.ExceptionActivity.IndexOutOfBoundsException(ExceptionActivity.java:80)
3. Log 分析如下:
IndexOutOfBoundsException Log分析
4. IndexOutOfBoundsException 解决方案
在使用时判断对象内容是否为0.
使用判断List 的size是否为0
四、ActivityNotFoundException
===========================
ActivityNotFoundException 常见于Eclipse 开发Android中,Android studio 已经帮忙自动生成Activity,以及布局文件。
主要原因是未在AndroidMainfest.xml文件中注册,如未注册,会引起app crash ,crash log如下:
ActivityNotFoundException: Unable to find explicit activity class
1. ActivityNotFoundException 代码举例
比如以下代码会引起此异常
Activity未在Androidmainfest.xml 中注册会引起ActivityNotFoundException
2. ActivityNotFoundException Log 举例
- Log信息如下:
12-27 17:46:05.994 17893 17893 E AndroidRuntime: Caused by: android.content.ActivityNotFoundException: Unable to find explicit activity class {com.programandroid/com.programandroid.Test.TestActivity}; have you declared this activity in your AndroidManifest.xml? 12-27 17:46:05.994 17893 17893 E AndroidRuntime: at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1810)
3. Log 分析如下:
ActivityNotFoundException Log分析
4. ActivityNotFoundException 解决方案
在AndroidMainfest.xml中注册即可
四大组件一定,一定要在AndroidMainfest.xml 中注册
五、IllegalStateException
=======================
IllegalStateException 非法状态异常,是因为软件中代码状态非法导致的。
以下代码会引起IllegalStateException 。当Button控件声明android:onClick="IllegalStateException" 却未在Java代码中使用时,点击Button,就会出现此类异常。
1. IllegalStateException 代码举例
IllegalStateException 代码举例
2. IllegalStateException Log 举例
- log信息如下:
12-27 16:07:41.158 1715 1715 E AndroidRuntime: FATAL EXCEPTION: main 12-27 16:07:41.158 1715 1715 E AndroidRuntime: Process: com.programandroid, PID: 1715 12-27 16:07:41.158 1715 1715 E AndroidRuntime: java.lang.IllegalStateException: Could not find method IllegalStateException(View) in a parent or ancestor Context for android:onClick attribute defined on view class android.widget.Button with id 'btn_on_click' 12-27 16:07:41.158 1715 1715 E AndroidRuntime: at android.view.ViewDeclaredOnClickListener.onClick(View.java:4740)
3. IllegalStateException Log分析如下:
IllegalStateException Log截图
4. IllegalStateException 解决方案
IllegalStateException 类异常很多,不同的代码会有不同的解决方案,上述举例解决方案如下
IllegalStateException
六、 ArrayIndexOutOfBoundsException 数组越界异常
========================================
数组在代码中经常被用到,当适用数组下标不当时,就会出现ArrayIndexOutOfBoundsException。比如数组长度为4,但你要引用下标为5的元素,这时候,就会异常crash。
1. ArrayIndexOutOfBoundsException 代码举例:
public static void ArrayIndexOutOfBounds() { String[] mStrings = { "a", "b", "c", "d" }; String testsString = mStrings[5]; }
ArrayIndexOutOfBoundsException 代码举例
2. ArrayIndexOutOfBoundsException Log举例:
最后
在此为大家准备了四节优质的Android高级进阶视频:
架构师项目实战——全球首批Android开发者对Android架构的见解
附相关架构及资料
领取获取往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。