Crash Exception 在Android 中经常会遇到,那么遇到异常我们该如何解决,本文将举例解决部分Android看法中遇到的异常。

  1. NullPointerException 空指针
  2. ClassCastException 类型转换异常
  3. IndexOutOfBoundsException 下标越界异常
  4. ActivityNotFoundException Activity未找到异常
  5. IllegalStateException 非法状态异常
  6. ArrayIndexOutOfBoundsException 数组越界异常
  7. SecurityException 安全异常

1. NullPointerException 空指针

NullPointerException在开发中经常会碰到,比如引用的对象为空,数组为空等。

    1. 数组 NullPointerException

不能向一个null数组元素赋值,获取长度,否则报
NullPointerException: Attempt to write to null array
NullPointerException Attempt to get length of null array,以下代码会引起上面两种空指针异常。

数组NullPointerException 代码举例

Android中Crash(闪退,崩溃)的一般问题与解决方案_第1张图片

NullPointerException 代码举例

数组NullPointerException Log 举例

  • Log 信息如下

第一次 NullPointerException 如下

 
  1. 12-27 17:17:44.627 8839 8839 E AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to get length of null array

  2. 12-27 17:17:44.627 8839 8839 E AndroidRuntime: at com.programandroid.Exception.NullPointerException.ArrayNullPointer(NullPointerException.java:32)

Log 分析如下

数组NullPointerException

第二次NullPointerException 如下

 
  1. 12-27 17:23:24.168 11649 11649 E AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to write to null array

  2. 12-27 17:23:24.168 11649 11649 E AndroidRuntime: at com.programandroid.Exception.NullPointerException.ArrayNullPointer(NullPointerException.java:34)

  3. 12-27 17:23:24.168 11649 11649 E AndroidRuntime: at com.programandroid.Exception.ExceptionActivity.NullPointerException(ExceptionActivity.java:37)

Log 分析如下

null 数组元素赋值异常

    1. Object 对象 NullPointerException

对象空指针,是因为引用一个null 对象,进而导致空指针,常报以下错误
Attempt to invoke a virtual method on a null object reference,以下代码可能会引起空指针异常。

object 对象 NullPointerException 代码举例

Android中Crash(闪退,崩溃)的一般问题与解决方案_第2张图片

Object 对象 NullPointerException

object 对象 NullPointerException log 举例

  • Log 信息如下:
 
  1. 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

  2. 12-27 17:28:22.565 12725 12725 E AndroidRuntime: at com.programandroid.Exception.NullPointerException.ListNullPointer(NullPointerException.java:45)

  3. 12-27 17:28:22.565 12725 12725 E AndroidRuntime: at com.programandroid.Exception.ExceptionActivity.NullPointerException(ExceptionActivity.java:37)

object 对象 NullPointerException Log 分析如下:

Object NullPointerException

NullPointerException 解决方案

    1. 使用时多注意判断对象是否为空

Android中Crash(闪退,崩溃)的一般问题与解决方案_第3张图片

使用对象是,最好判断对象是否为空

    1. 使用try-catch将抛出的异常抓住

Android中Crash(闪退,崩溃)的一般问题与解决方案_第4张图片

try-catch 代码异常,防止app crash

    1. 终极解决方案,优化代码逻辑,从根本上解决问题。

2. ClassCastException 类型转换异常

ClassCastException 类型转换异常:
此异常发生在类型转换时,并且在编译期间,编译器不会提示报错,但是当运行时,如果存在此异常,可能会导致app崩溃 crash
比如当发生以下情况时,类型转换异常就会发生

  1. 父类强制转换为子类时,ClassCastException 就会发生

1. 以下代码 会引起 ClassCastException

ClassCastException 代码举例

Android中Crash(闪退,崩溃)的一般问题与解决方案_第5张图片

ClassCastException 类型转换异常举例

ClassCastException Log 举例

ClassCastException通常会打印以下类似信息

 
  1. Caused by: java.lang.ClassCastException:

  2. com.programandroid.Exception.ExceptionActivity$

  3. Fruit cannot be cast to com.programandroid.Exception.ExceptionActivity$Apple

ClassCastException Log 分析

ClassCastException log 分析

ClassCastException 解决方案

使用try-catch抓住异常,或者从代码上解决根本问题。

Android中Crash(闪退,崩溃)的一般问题与解决方案_第6张图片

使用 try-catch抓住 ClassCastException异常

2. Android 手机 Settings ClassCastException 解决方案

举例是为了更好的解决开发中的异常。比如在开发中,使用 monkey 测试Settings模块时,报出的 ClassCastExceptionSettings代码比较多,一时也无法看完,此时,try-catch 也是一种不错的选择。
比如monkey测试某平台代码时,报出以下异常

Settings ClassCastException Log 举例

  • log 信息如下:
 
  1. FATAL EXCEPTION: ApplicationsState.Loader

  2. 01-05 03:36:56.101 6304 6941 E AndroidRuntime: Process: com.android.settings, PID: 6304

  3. 01-05 03:36:56.101 6304 6941 E AndroidRuntime: java.lang.ClassCastException:

  4. com.android.settings.datausage.AppStateDataUsageBridge$DataUsageState

  5. cannot be cast to com.android.settings.notification.NotificationBackend$AppRow

  6.  
  7. 01-05 03:36:56.101 6304 6941 E AndroidRuntime: at com.android.settings.applications.AppStateNotificationBridge$3.filterApp(AppStateNotificationBridge.java:110)

Settings ClassCastException Log分析

Android中Crash(闪退,崩溃)的一般问题与解决方案_第7张图片

Settings ClassCastException Log1

Android中Crash(闪退,崩溃)的一般问题与解决方案_第8张图片

Settings ClassCastException Log2

Setting crash ClassCastException 解决方案:

Android中Crash(闪退,崩溃)的一般问题与解决方案_第9张图片

try-catch 异常报错的地方

Android中Crash(闪退,崩溃)的一般问题与解决方案_第10张图片

try-catch 异常报错的地方

Android中Crash(闪退,崩溃)的一般问题与解决方案_第11张图片

try-catch 异常报错的地方

3. IndexOutOfBoundsException 下标越界异常

List 在开发中经常会被用的,那么错误的使用下标,将会导致IndexOutOfBoundsException越界异常。以下代码就会引起IndexOutOfBoundsException异常

IndexOutOfBoundsException 代码举例

Android中Crash(闪退,崩溃)的一般问题与解决方案_第12张图片

IndexOutOfBoundsException 异常举例

IndexOutOfBoundsException Log举例

  • Log 信息如下:
 
  1. 12-27 17:41:24.231 16891 16891 E AndroidRuntime: Caused by: java.lang.IndexOutOfBoundsException: Index: 0, Size: 0

  2. 12-27 17:41:24.231 16891 16891 E AndroidRuntime: at java.util.ArrayList.get(ArrayList.java:411)

  3. 12-27 17:41:24.231 16891 16891 E AndroidRuntime: at com.programandroid.Exception.IndexOutOfBoundsException.isAppOnRecent(IndexOutOfBoundsException.java:40)

  4. 12-27 17:41:24.231 16891 16891 E AndroidRuntime: at com.programandroid.Exception.ExceptionActivity.IndexOutOfBoundsException(ExceptionActivity.java:80)

Log 分析如下:

IndexOutOfBoundsException Log分析

IndexOutOfBoundsException 解决方案

在使用时判断对象内容是否为0.

Android中Crash(闪退,崩溃)的一般问题与解决方案_第13张图片

使用判断List 的size是否为0

4. ActivityNotFoundException

ActivityNotFoundException 常见于Eclipse 开发Android中,Android studio 已经帮忙自动生成Activity,以及布局文件。
主要原因是未在AndroidMainfest.xml文件中注册,如未注册,会引起app crash ,crash log如下:
ActivityNotFoundException: Unable to find explicit activity class

ActivityNotFoundException 代码举例

比如以下代码会引起此异常

 

Activity未在Androidmainfest.xml 中注册会引起ActivityNotFoundException

ActivityNotFoundException Log 举例

  • Log信息如下:
 
  1. 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?

  2. 12-27 17:46:05.994 17893 17893 E AndroidRuntime: at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1810)

Log 分析如下:

Android中Crash(闪退,崩溃)的一般问题与解决方案_第14张图片

ActivityNotFoundException Log分析

ActivityNotFoundException 解决方案

AndroidMainfest.xml中注册即可

Android中Crash(闪退,崩溃)的一般问题与解决方案_第15张图片

四大组件一定,一定要在AndroidMainfest.xml 中注册

 

5. IllegalStateException

IllegalStateException 非法状态异常,是因为软件中代码状态非法导致的。
以下代码会引起IllegalStateException 。当Button控件声明android:onClick="IllegalStateException" 却未在Java代码中使用时,点击Button,就会出现此类异常。

IllegalStateException 代码举例

Android中Crash(闪退,崩溃)的一般问题与解决方案_第16张图片

IllegalStateException 代码举例

IllegalStateException Log 举例

  • log信息如下:
 
  1. 12-27 16:07:41.158 1715 1715 E AndroidRuntime: FATAL EXCEPTION: main

  2. 12-27 16:07:41.158 1715 1715 E AndroidRuntime: Process: com.programandroid, PID: 1715

  3. 12-27 16:07:41.158 1715 1715 E AndroidRuntime: java.lang.IllegalStateException:

  4. Could not find method IllegalStateException(View) in a parent

  5. or ancestor Context for android:onClick attribute defined on view class

  6. android.widget.Button with id 'btn_on_click'

  7. 12-27 16:07:41.158 1715 1715 E AndroidRuntime: at android.view.View$DeclaredOnClickListener.resolveMethod(View.java:4781)

  8. 12-27 16:07:41.158 1715 1715 E AndroidRuntime: at android.view.View$DeclaredOnClickListener.onClick(View.java:4740)

IllegalStateException Log分析如下:

Android中Crash(闪退,崩溃)的一般问题与解决方案_第17张图片

IllegalStateException Log截图

IllegalStateException 解决方案

IllegalStateException 类异常很多,不同的代码会有不同的解决方案,上述举例解决方案如下

Android中Crash(闪退,崩溃)的一般问题与解决方案_第18张图片

IllegalStateException

 

6 . ArrayIndexOutOfBoundsException 数组越界异常

数组在代码中经常被用到,当适用数组下标不当时,就会出现ArrayIndexOutOfBoundsException。比如数组长度为4,但你要引用下标为5的元素,这时候,就会异常crash

ArrayIndexOutOfBoundsException 代码举例:

Android中Crash(闪退,崩溃)的一般问题与解决方案_第19张图片

ArrayIndexOutOfBoundsException 代码举例

ArrayIndexOutOfBoundsException Log举例:

  • Log信息如下:
 
  1. 12-27 17:51:15.420 19185 19185 E AndroidRuntime: Caused by: java.lang.ArrayIndexOutOfBoundsException: length=4; index=5

  2. 12-27 17:51:15.420 19185 19185 E AndroidRuntime: at com.programandroid.Exception.ArrayIndexOutOfBoundsException.ArrayIndexOutOfBounds(ArrayIndexOutOfBoundsException.java:20)

  3. 12-27 17:51:15.420 19185 19185 E AndroidRuntime: at com.programandroid.Exception.ExceptionActivity.ArrayIndexOutOfBoundsException(ExceptionActivity.java:105)

  4. 12-27 17:51:15.420 19185 19185 E AndroidRuntime: ... 11 more

ArrayIndexOutOfBoundsException Log分析如下:

ArrayIndexOutOfBoundsException Log分析

ArrayIndexOutOfBoundsException解决方案

    1. 正确使用数组下标
    1. 如果不确定数组长度,请先获取长度,然后在判断下标是否大于等于数组长度。
    1. try-catch 抓住异常,防止crash,但不能从根本上解决问题。

7. SecurityException 安全异常

SecurityException 安全异常在Android 中也会经常发生,主要是Android 的安全机制原因造成的,为了管理应用获取手机的一些敏感信息,Android安全机制规定,必须在AndroidMainfest.xml 文件中声明,并且,Android 6.0之后,获取手机敏感信息时候,需要动态申请权限,只有用户授权后才可以获取手机敏感信息。

SecurityException 代码举例

获取手机的IMEI 号属于手机的敏感信息

 

Android中Crash(闪退,崩溃)的一般问题与解决方案_第20张图片

获取手机IMEI号

SecurityException log举例

 
  1. 12-27 18:05:55.663 21467 21467 E AndroidRuntime: Caused by: java.lang.SecurityException: getDeviceId: Neither user 10117 nor current process has android.permission.READ_PHONE_STATE.

  2. 12-27 18:05:55.663 21467 21467 E AndroidRuntime: at android.os.Parcel.readException(Parcel.java:1683)

  3. 12-27 18:05:55.663 21467 21467 E AndroidRuntime: at android.os.Parcel.readException(Parcel.java:1636)

  4. 12-27 18:05:55.663 21467 21467 E AndroidRuntime: at com.android.internal.telephony.ITelephony$Stub$Proxy.getDeviceId(ITelephony.java:4281)

SecurityException log 分析

SecurityException log 分析

SecurityException 解决方案

Android 6.0之前,在AndroidMainfest.xml中申请权限即可,
Android 6.0 之后,请动态申请权限。

Android中Crash(闪退,崩溃)的一般问题与解决方案_第21张图片

AndroidMainfest.xml 中申请权限

更多相关文章

  1. 【Android休眠】之Android对PowerKey事件的处理(1)代码流程
  2. android声音调整源代码分析
  3. Android 用代码获取基站号(cell)和小区号(lac)
  4. Android第一行代码(第二版)
  5. android手机通讯录备份还原代码
  6. 详解Android获取系统内核版本的方法与实现代码
  7. Android SDK升级至revision 12后的一个Bug及解决方案
  8. android典型代码系列(二十八)------通话记录的操作
  9. 【Android】Android清除本地数据缓存代码

随机推荐

  1. Android 四大组件,五大存储,六大布局
  2. Android Studio打包Signed APK 碰到的一
  3. Android图片压缩及内存缓存
  4. Android开发小技巧
  5. Android之ListActivity(一):布局与数据绑定
  6. 教你用电脑从 Google Play 下载 Android(
  7. 关于Android(安卓)Force Close 出现的原
  8. Android Binder 机制详解
  9. Android 开发中常用到的设计模式
  10. android竖向进度条简单实现