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.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)12−2716: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@5f3161e01−3009:10:26.2572368123681WSystem.err:atandroid.app.LoadedApk.forgetServiceDispatcher(LoadedApk.java:1363)01−3009:10:26.2572368123681WSystem.err:atandroid.app.ContextImpl.unbindService(ContextImpl.java:1499)01−3009:10:26.2572368123681WSystem.err:atandroid.content.ContextWrapper.unbindService(ContextWrapper.java:648)01−3009:10:26.2572368123681WSystem.err:atcom.programandroid.Exception.ExceptionActivity.ServiceNotRegisteredCrash(ExceptionActivity.java:276)01−3009:10:26.2572368123681WSystem.err:atjava.lang.reflect.Method.invoke(NativeMethod)01−3009: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 异常举例
九、BadTokenException 解决方案
========================
1. log 举例
03-12 14:55:13.734 5564 5564 E AndroidRuntime: FATAL EXCEPTION: main 03-12 14:55:13.734 5564 5564 E AndroidRuntime: Process: com.android.fmradio, PID: 5564 03-12 14:55:13.734 5564 5564 E AndroidRuntime: java.lang.RuntimeException: Error receiving broadcast Intent { act=android.intent.action.HEADSET_PLUG flg=0x40000010 (has extras) } in com.android.fmradio.FmService F m S e r v i c e B r o a d c a s t R e c e i v e r @ b 3 d 2 a 0303 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : a t a n d r o i d . a p p . L o a d e d A p k FmServiceBroadcastReceiver@b3d2a03 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.app.LoadedApk FmServiceBroadcastReceiver@b3d2a0303−1214:55:13.73455645564EAndroidRuntime:atandroid.app.LoadedApkReceiverDispatcher A r g s . l a m b d a Args.lambda Args.lambdagetRunnable 0 ( L o a d e d A p k . j a v a : 1401 ) 03 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : a t a n d r o i d . a p p . − 0(LoadedApk.java:1401) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.app.- 0(LoadedApk.java:1401)03−1214:55:13.73455645564EAndroidRuntime:atandroid.app.− L a m b d a Lambda LambdaLoadedApk R e c e i v e r D i s p a t c h e r ReceiverDispatcher ReceiverDispatcherArgs B u m D X 2 U K s n x L V r E 6 U J s J Z k o t u A . r u n ( U n k n o w n S o u r c e : 2 ) 03 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : a t a n d r o i d . o s . H a n d l e r . h a n d l e C a l l b a c k ( H a n d l e r . j a v a : 873 ) 03 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : a t a n d r o i d . o s . H a n d l e r . d i s p a t c h M e s s a g e ( H a n d l e r . j a v a : 99 ) 03 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : a t a n d r o i d . o s . L o o p e r . l o o p ( L o o p e r . j a v a : 193 ) 03 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : a t a n d r o i d . a p p . A c t i v i t y T h r e a d . m a i n ( A c t i v i t y T h r e a d . j a v a : 6702 ) 03 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : 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 ) 03 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : a t c o m . a n d r o i d . i n t e r n a l . o s . R u n t i m e I n i t _BumDX2UKsnxLVrE6UJsJZkotuA.run(Unknown Source:2) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.os.Handler.handleCallback(Handler.java:873) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:99) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.os.Looper.loop(Looper.java:193) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:6702) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at com.android.internal.os.RuntimeInit BumDX2UKsnxLVrE6UJsJZkotuA.run(UnknownSource:2)03−1214:55:13.73455645564EAndroidRuntime:atandroid.os.Handler.handleCallback(Handler.java:873)03−1214:55:13.73455645564EAndroidRuntime:atandroid.os.Handler.dispatchMessage(Handler.java:99)03−1214:55:13.73455645564EAndroidRuntime:atandroid.os.Looper.loop(Looper.java:193)03−1214:55:13.73455645564EAndroidRuntime:atandroid.app.ActivityThread.main(ActivityThread.java:6702)03−1214:55:13.73455645564EAndroidRuntime:atjava.lang.reflect.Method.invoke(NativeMethod)03−1214:55:13.73455645564EAndroidRuntime:atcom.android.internal.os.RuntimeInitMethodAndArgsCaller.run(RuntimeInit.java:493) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:911) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: Caused by: android.view.WindowManager B a d T o k e n E x c e p t i o n : U n a b l e t o a d d w i n d o w a n d r o i d . v i e w . V i e w R o o t I m p l BadTokenException: Unable to add window android.view.ViewRootImpl BadTokenException:Unabletoaddwindowandroid.view.ViewRootImplW@f652dba – permission denied for window type 2003 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.view.ViewRootImpl.setView(ViewRootImpl.java:851) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:356) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:93) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.app.Dialog.show(Dialog.java:329) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at com.android.fmradio.FmService F m S e r v i c e B r o a d c a s t R e c e i v e r . o n R e c e i v e ( F m S e r v i c e . j a v a : 322 ) 03 − 1214 : 55 : 13.73455645564 E A n d r o i d R u n t i m e : a t a n d r o i d . a p p . L o a d e d A p k FmServiceBroadcastReceiver.onReceive(FmService.java:322) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.app.LoadedApk FmServiceBroadcastReceiver.onReceive(FmService.java:322)03−1214:55:13.73455645564EAndroidRuntime:atandroid.app.LoadedApkReceiverDispatcher A r g s . l a m b d a Args.lambda Args.lambdagetRunnable$0(LoadedApk.java:1391) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: … 8 more
2.产生原因
最后
针对于上面的问题,我总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料。
(包括Java在Android开发中应用、APP框架知识体系、高级UI、全方位性能调优,NDK开发,音视频技术,人工智能技术,跨平台技术等技术资料),希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。
加入社区》https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0
er.onReceive(FmService.java:322) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: at android.app.LoadedApk
R
e
c
e
i
v
e
r
D
i
s
p
a
t
c
h
e
r
ReceiverDispatcher
ReceiverDispatcherArgs.lambda$getRunnable$0(LoadedApk.java:1391) 03-12 14:55:13.734 5564 5564 E AndroidRuntime: … 8 more
2.产生原因
最后
针对于上面的问题,我总结出了互联网公司Android程序员面试涉及到的绝大部分面试题及答案,并整理做成了文档,以及系统的进阶学习视频资料。
(包括Java在Android开发中应用、APP框架知识体系、高级UI、全方位性能调优,NDK开发,音视频技术,人工智能技术,跨平台技术等技术资料),希望能帮助到你面试前的复习,且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。
[外链图片转存中…(img-s3IXQdQl-1725632020529)]
加入社区》https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0