热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android异常及性能优化系列之APPCrash

极力推荐Android开发大总结文章:欢迎收藏程序员Android力荐,Android开发者需要的必备技能Exception在Android中经常会遇到

640?wx_fmt=gif

640?wx_fmt=gif

极力推荐Android 开发大总结文章:欢迎收藏
程序员Android 力荐 ,Android 开发者需要的必备技能

640?wx_fmt=jpeg

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 代码举例

640?wx_fmt=png

NullPointerException 代码举例

数组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 array12-27 17:17:44.627  8839  8839 E AndroidRuntime:    at com.programandroid.Exception.NullPointerException.ArrayNullPointer(NullPointerException.java:32)

Log 分析如下

640?wx_fmt=png

数组NullPointerException

第二次NullPointerException 如下

12-27 17:23:24.168 11649 11649 E AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to write to null array12-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)

Log 分析如下

640?wx_fmt=png

null 数组元素赋值异常


  1. Object 对象 NullPointerException

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

object 对象 NullPointerException 代码举例

640?wx_fmt=png

Object 对象 NullPointerException

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 reference12-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)

object 对象 NullPointerException Log 分析如下:

640?wx_fmt=png

Object NullPointerException

NullPointerException 解决方案


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

640?wx_fmt=png

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


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

640?wx_fmt=png

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


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

2. ClassCastException 类型转换异常

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

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

1. 以下代码 会引起 ClassCastException

ClassCastException 代码举例

640?wx_fmt=png

ClassCastException 类型转换异常举例

ClassCastException Log 举例

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

Caused by: java.lang.ClassCastException:
com.programandroid.Exception.ExceptionActivity$
Fruit cannot be cast to com.programandroid.Exception.ExceptionActivity$Apple

ClassCastException Log 分析

640?wx_fmt=png

ClassCastException log 分析

ClassCastException 解决方案

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

640?wx_fmt=png

使用 try-catch抓住 ClassCastException异常

2. Android 手机 Settings ClassCastException 解决方案

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

Settings ClassCastException Log 举例

  • 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.AppStateDataUsageBridge$DataUsageState
                                                  cannot be cast to com.android.settings.notification.NotificationBackend$AppRow
                                                  01-05 03:36:56.101  6304  6941 E AndroidRuntime:    at com.android.settings.applications.AppStateNotificationBridge$3.filterApp(AppStateNotificationBridge.java:110)

Settings ClassCastException Log分析

640?wx_fmt=png

Settings ClassCastException Log1

640?wx_fmt=png

Settings ClassCastException Log2

Setting crash ClassCastException 解决方案:

640?wx_fmt=png

try-catch 异常报错的地方

640?wx_fmt=png

try-catch 异常报错的地方

640?wx_fmt=png

try-catch 异常报错的地方

3. IndexOutOfBoundsException 下标越界异常

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

IndexOutOfBoundsException 代码举例

640?wx_fmt=png

IndexOutOfBoundsException 异常举例

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)

Log 分析如下:

640?wx_fmt=png

IndexOutOfBoundsException Log分析

IndexOutOfBoundsException 解决方案

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

640?wx_fmt=png

使用判断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 代码举例

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


640?wx_fmt=png

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

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)

Log 分析如下:

640?wx_fmt=png

ActivityNotFoundException Log分析

ActivityNotFoundException 解决方案

AndroidMainfest.xml中注册即可

640?wx_fmt=png

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


5. IllegalStateException

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

IllegalStateException 代码举例

IllegalStateException 代码举例

IllegalStateException Log 举例

  • log信息如下:

12-27 16:07:41.158  1715  1715 E AndroidRuntime: FATAL EXCEPTION: main12-27 16:07:41.158  1715  1715 E AndroidRuntime: Process: com.programandroid, PID: 171512-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.View$DeclaredOnClickListener.resolveMethod(View.java:4781)12-27 16:07:41.158  1715  1715 E AndroidRuntime:    at android.view.View$DeclaredOnClickListener.onClick(View.java:4740)

IllegalStateException Log分析如下:

640?wx_fmt=png

IllegalStateException Log截图

IllegalStateException 解决方案

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

640?wx_fmt=png

IllegalStateException


6 . ArrayIndexOutOfBoundsException 数组越界异常

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

ArrayIndexOutOfBoundsException 代码举例:

640?wx_fmt=png

ArrayIndexOutOfBoundsException 代码举例

ArrayIndexOutOfBoundsException Log举例:

  • Log信息如下:

AndroidRuntime: Caused by: java.lang.ArrayIndexOutOfBoundsException: length=4; index=512-27 17:51:15.420 19185 19185 E AndroidRuntime:
     at com.programandroid.Exception.ArrayIndexOutOfBoundsException.ArrayIndexOutOfBounds(ArrayIndexOutOfBoundsException.java:20)12-27 17:51:15.420 19185 19185 E AndroidRuntime:
      at com.programandroid.Exception.ExceptionActivity.ArrayIndexOutOfBoundsException(ExceptionActivity.java:105)12-27 17:51:15.420 19185 19185 E AndroidRuntime:  
    

ArrayIndexOutOfBoundsException Log分析如下:

640?wx_fmt=png

ArrayIndexOutOfBoundsException Log分析

ArrayIndexOutOfBoundsException解决方案


  1. 正确使用数组下标


  1. 如果不确定数组长度,请先获取长度,然后在判断下标是否大于等于数组长度。


  1. try-catch 抓住异常,防止crash,但不能从根本上解决问题。

7. SecurityException 安全异常

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

SecurityException 代码举例

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


640?wx_fmt=png

获取手机IMEI号

SecurityException log举例

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.
12-27 18:05:55.663 21467 21467 E AndroidRuntime:    at android.os.Parcel.readException(Parcel.java:1683)
12-27 18:05:55.663 21467 21467 E AndroidRuntime:    at android.os.Parcel.readException(Parcel.java:1636)
12-27 18:05:55.663 21467 21467 E AndroidRuntime:    at com.android.internal.telephony.ITelephony$Stub$Proxy.getDeviceId(ITelephony.java:4281)

SecurityException log 分析

640?wx_fmt=png

SecurityException log 分析

SecurityException 解决方案

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

640?wx_fmt=png

AndroidMainfest.xml 中申请权限

640?wx_fmt=jpeg

至此,本篇已结束,如有不对的地方,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!

640?wx_fmt=jpeg

如有侵权,请联系小编,小编对此深感抱歉,届时小编会删除文章,立即停止侵权行为,请您多多包涵。640?wx_fmt=other

既然都看到这里,领两个红包在走吧!
以下两个红包每天都可以领取

1.支付宝搜索 522398497,或扫码支付宝红包海报。

支付宝扫一扫,每天领取大红包

2.微信红包,微信扫一扫即可领取红包

微信扫一扫,每天领取微信红包



推荐阅读
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • 在 Flutter 开发过程中,开发者经常会遇到 Widget 构造函数中的可选参数 Key。对于初学者来说,理解 Key 的作用和使用场景可能是一个挑战。本文将详细探讨 Key 的概念及其应用场景,并通过实例帮助你更好地掌握这一重要工具。 ... [详细]
  • 在Java中,this是一个引用当前对象的关键字。如何通过this获取并显示其所指向的对象的属性和方法?本文详细解释了this的用法及其背后的原理。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 在维护公司项目时,发现按下手机的某个物理按键后会激活相应的服务,并在屏幕上模拟点击特定坐标点。本文详细介绍了如何使用ADB Shell Input命令来模拟各种输入事件,包括滑动、按键和点击等。 ... [详细]
  • andr ... [详细]
  • 本文介绍了两种方法,用于检测 Android 设备是否开启了开发者模式。第一种方法通过检查 USB 调试模式的状态,第二种方法则直接判断开发者选项是否启用。这两种方法均提供了代码示例和详细解释。 ... [详细]
  • ASP.NET MVC中Area机制的实现与优化
    本文探讨了在ASP.NET MVC框架中,如何通过Area机制有效地组织和管理大规模应用程序的不同功能模块。通过合理的文件夹结构和命名规则,开发人员可以更高效地管理和扩展项目。 ... [详细]
  • 编写了几个500行左右代码的程序,但基本上解决问题还是面向过程的思维,如何从问题中抽象出类,形成类的划分和设计,从而用面向对象的思维解决问题?有这方面的入门好书吗?最好是结合几个具体的案例分析的 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
  • Qt QTableView 内嵌控件的实现方法
    本文详细介绍了在 Qt QTableView 中嵌入控件的多种方法,包括使用 QItemDelegate、setIndexWidget 和 setIndexWidget 结合布局管理器。每种方法都有其适用场景和优缺点。 ... [详细]
  • 社交网络中的级联行为 ... [详细]
  • 本文介绍了在Java环境中使用PDFBox和XPDF工具从PDF文件中提取文本内容的方法。重点讨论了处理中文字符集及解决相关错误的技术细节,特别是针对某些特定格式的PDF文件(如网上填写的报名表和下载的论文)遇到的问题及解决方案。 ... [详细]
author-avatar
Zh_jodie_776
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有