Android Crash 案例分析,2024届毕业生还没找到Android开发工作

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

3. ClassCastException Log 分析


ClassCastException log 分析

4. ClassCastException 解决方案


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

使用 try-catch抓住 ClassCastException异常

5. Android 手机 Settings ClassCastException 解决方案


举例是为了更好的解决开发中的异常。比如在开发中,使用 monkey 测试Settings模块时,报出的 ClassCastExceptionSettings代码比较多,一时也无法看完,此时,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.AppStateDataUsageBridge D a t a U s a g e S t a t e c a n n o t b e c a s t t o c o m . a n d r o i d . s e t t i n g s . n o t i f i c a t i o n . N o t i f i c a t i o n B a c k e n d DataUsageState cannot be cast to com.android.settings.notification.NotificationBackend DataUsageStatecannotbecasttocom.android.settings.notification.NotificationBackendAppRow 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.View D e c l a r e d O n C l i c k L i s t e n e r . r e s o l v e M e t h o d ( V i e w . j a v a : 4781 ) 12 − 2716 : 07 : 41.15817151715 E A n d r o i d R u n t i m e : a t a n d r o i d . v i e w . V i e w DeclaredOnClickListener.resolveMethod(View.java:4781) 12-27 16:07:41.158 1715 1715 E AndroidRuntime: at android.view.View DeclaredOnClickListener.resolveMethod(View.java:4781)122716:07:41.15817151715EAndroidRuntime:atandroid.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举例:


  • Log信息如下:

12-27 17:51:15.420 19185 19185 E AndroidRuntime: Caused by: java.lang.ArrayIndexOutOfBoundsException: length=4; index=5 12-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: … 11 more

3. ArrayIndexOutOfBoundsException Log分析如下:


ArrayIndexOutOfBoundsException Log分析

4. ArrayIndexOutOfBoundsException解决方案


  • 1.正确使用数组下标

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

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

七、SecurityException 安全异常

========================

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

1. SecurityException 代码举例


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

/** * * * * * */ public static String getIMEI(Context context) { TelephonyManager tm = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); String deviceId = tm.getDeviceId(); if (deviceId == null) { return “UnKnown”; } else { return deviceId; } }

获取手机IMEI号

2. 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 S t u b Stub StubProxy.getDeviceId(ITelephony.java:4281)

3. SecurityException log 分析


SecurityException log 分析

4. SecurityException 解决方案


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

Android 6.0 之后,请动态申请权限。

AndroidMainfest.xml 中申请权限

八、IllegalArgumentException: Service not registered 服务未注册异常

==========================================================

1.报错信息如下:


01-30 09:10:26.257 23681 23681 W System.err: java.lang.IllegalArgumentException: Service not registered: com.programandroid.Exception.ExceptionActivity 1 @ 5 f 3161 e 01 − 3009 : 10 : 26.2572368123681 W S y s t e m . e r r : a t a n d r o i d . a p p . L o a d e d A p k . f o r g e t S e r v i c e D i s p a t c h e r ( L o a d e d A p k . j a v a : 1363 ) 01 − 3009 : 10 : 26.2572368123681 W S y s t e m . e r r : a t a n d r o i d . a p p . C o n t e x t I m p l . u n b i n d S e r v i c e ( C o n t e x t I m p l . j a v a : 1499 ) 01 − 3009 : 10 : 26.2572368123681 W S y s t e m . e r r : a t a n d r o i d . c o n t e n t . C o n t e x t W r a p p e r . u n b i n d S e r v i c e ( C o n t e x t W r a p p e r . j a v a : 648 ) 01 − 3009 : 10 : 26.2572368123681 W S y s t e m . e r r : a t c o m . p r o g r a m a n d r o i d . E x c e p t i o n . E x c e p t i o n A c t i v i t y . S e r v i c e N o t R e g i s t e r e d C r a s h ( E x c e p t i o n A c t i v i t y . j a v a : 276 ) 01 − 3009 : 10 : 26.2572368123681 W S y s t e m . e r r : a t j a v a . l a n g . r e f l e c t . M e t h o d . i n v o k e ( N a t i v e M e t h o d ) 01 − 3009 : 10 : 26.2582368123681 W S y s t e m . e r r : a t a n d r o i d . v i e w . V i e w 1@5f3161e 01-30 09:10:26.257 23681 23681 W System.err: at android.app.LoadedApk.forgetServiceDispatcher(LoadedApk.java:1363) 01-30 09:10:26.257 23681 23681 W System.err: at android.app.ContextImpl.unbindService(ContextImpl.java:1499) 01-30 09:10:26.257 23681 23681 W System.err: at android.content.ContextWrapper.unbindService(ContextWrapper.java:648) 01-30 09:10:26.257 23681 23681 W System.err: at com.programandroid.Exception.ExceptionActivity.ServiceNotRegisteredCrash(ExceptionActivity.java:276) 01-30 09:10:26.257 23681 23681 W System.err: at java.lang.reflect.Method.invoke(Native Method) 01-30 09:10:26.258 23681 23681 W System.err: at android.view.View 1@5f3161e013009:10:26.2572368123681WSystem.err:atandroid.app.LoadedApk.forgetServiceDispatcher(LoadedApk.java:1363)013009:10:26.2572368123681WSystem.err:atandroid.app.ContextImpl.unbindService(ContextImpl.java:1499)013009:10:26.2572368123681WSystem.err:atandroid.content.ContextWrapper.unbindService(ContextWrapper.java:648)013009:10:26.2572368123681WSystem.err:atcom.programandroid.Exception.ExceptionActivity.ServiceNotRegisteredCrash(ExceptionActivity.java:276)013009:10:26.2572368123681WSystem.err:atjava.lang.reflect.Method.invoke(NativeMethod)013009:10:26.2582368123681WSystem.err:atandroid.view.ViewDeclaredOnClickListener.onClick(View.java:4744) 01-30 09:10:26.258 23681 23681 W System.err: at android.view.View.performClick(View.java:5675)

2.Log分析如下:


Log 分析

此异常经常发生在错误的解除绑定服务造成的,解决方法:

1.解除绑定服务之前,先判断是否绑定过,只有绑定过后才可以解绑

2.使用try-catch 抓取住异常

代码举例如下:

Service not registered 异常举例

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
img

尾声

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

进阶学习视频

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

90)]

尾声

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。
[外链图片转存中…(img-6nU2MfGY-1711908046790)]
当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

进阶学习视频

[外链图片转存中…(img-BtRizBbW-1711908046791)]

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

[外链图片转存中…(img-csSXfNY1-1711908046791)]

本文已被CODING开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》收录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值