技术标签: android
Crash问题分析定位:通过Log文件夹下全局搜am_crash,此时会把log文件下下所有的包含am_crash的行显示出来
一.导致Android Crash 问题的主要类型
JAVA application crash
1.ANR(application no response) crash
2.JAVA uncaught exception crash
System crash
1.Process Crash(Native Crash or C/Delvik Crash)
2.Kernel Crash
3.Modem Crash
1) HW Watchdog
2)SW Watchdog
3)Apps Keepalive
4)Other
由上图可见,在APP层面我们出现并能解决的BUG 集中在App Crash 和System crash 层;
二. ANR(application no response)
(一)导致ANR主要有3种原因:
ANR的产生原因就是由于应用程序的主线程响应超时导致的,只要超过最大限制的超时时间就必然会产生ANR:
1.KeyDispatchTimeout(5 seconds)–按键或触摸事件在特定时间内无响应;(输入事件)
2. BroadcastTimeout(10 seconds)–BroadcastReceiver在特定时间内无法处理完成;(特定操作)
3. ServiceTimeout(20 seconds)–Service在特定的时间内无法处理完成;(特定操作)
(二)处理方法
1.获取实时log: adb logcat -v time >anr.log 或 adb logcat -v time | tee anr.log
2.获取traces.txt文件:adb pull /data/anr/traces.txt C:\monkey
(三)分析log
从log可以看出ANR的类型:
1.cpu使用量接近100%,说明当前设备很忙,有可能是cpu饥饿导致ANR;
2.cpu使用量很低,说明主线程有可能被阻塞;
3.IOwait很高,说明有可能是主线程在进行I/O操作导致ANR;
(四)分析traces
三. Java Crash
(一)Error and exception 的区别
Error(错误):表示系统级的错误和程序不必处理的异常,是java运行环境中的内部错误或者硬件问题,比如,内存资源不足等,对于这种错误,程序基本无能为力,除了退出运行外别无选择;
Exception(异常):表示需要捕捉或者需要程序进行处理的异常,它处理的是因为程序设计的瑕疵而引起的问题或者在外的输入等引起的一般性问题,是程序必须处理的;
(二)常见Java Error and exception
1.现象:系统弹出窗口提示用户某进程崩溃或者直接闪退;
2.Throwable类是Java语言中所有错误或异常的超类;
(1).Error
a.OutOfMemory
b.IOError
c.StackOverflowError
d.UnsatisfiedLinkError
e.其它Error…;
常见Error列表:
(2).Exception
a.RuntimeException (最常见)
b.Checked(编译时检查)
c.其它Exception…;
常见Exception列表:
-----------------------------------------------------------------下面是各种Crash 案例分析------------------------------------------------------
一、NullPointerException 空指针
NullPointerException在开发中经常会碰到,比如引用的对象为空,数组为空等等都会引起空指针异常,如不及时处理,就会导致 应用Crash。
不能向一个null数组元素赋值,获取长度,否则报
NullPointerException: Attempt to write to null array和
NullPointerException Attempt to get length of null array,以下代码会引起上面两种空指针异常。
1 |
public static void ArrayNullPointer() {
|
NullPointerException 代码举例
Log 信息如下
获取 空数组长度导致的 NullPointerException 如下:
1 |
12-27 17:17:44.627 8839 8839 E AndroidRuntime: Caused by: java.lang.NullPointerException: |
数组NullPointerException
空数组无法获取下标内容,如果获取则会导致NullPointerException
1 |
12-27 17:23:24.168 11649 11649 E AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to write to null array |
对象空指针,这个是常见的空指针,主要是因为引用一个null 对象,进而导致空指针,常报以下错误
Attempt to invoke a virtual method on a null object reference,以下代码可能会引起空指针异常。
简单代码举例如下:
1 |
public static void ListNullPointer() {
|
Object 对象 NullPointerException
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 |
Object NullPointerException
规避空指针举例如下:
1.使用时多注意判断对象是否为空
1 |
public static void ListNullPointer() {
|
使用对象是,最好判断对象是否为空
2.使用try-catch将抛出的异常抓住
try-catch 可以抓住抛出的异常,使应用程序不崩溃,但是,这个不是从根本上解决问题,会引起一些莫名其妙的问题。
1 |
public static void ListNullPointer() {
|
try-catch 代码异常,防止app crash
二、 ClassCastException 类型转换异常
ClassCastException 类型转换异常:
此异常发生在类型转换时,并且在编译期间,编译器不会提示报错,但是当运行时,如果存在此异常,可能会导致app崩溃 crash。
比如当父类强制转换为子类时,ClassCastException 就会发生
请勿 父类强制转换为子类,否则就会发生ClassCastException异常。
1 |
public void ClassCastExample() {
|
ClassCastException 类型转换异常举例
ClassCastException通常会打印以下类似信息
1 |
Caused by: java.lang.ClassCastException: |
ClassCastException log 分析
使用try-catch抓住异常,或者从代码上解决根本问题。
使用 try-catch抓住 ClassCastException异常
举例是为了更好的解决开发中的异常。比如在开发中,使用 monkey 测试Settings模块时,报出的 ClassCastException,Settings代码比较多,一时也无法看完,此时,try-catch 也是一种不错的选择。
比如monkey测试某平台代码时,报出以下异常
log 信息如下:
1 |
FATAL EXCEPTION: ApplicationsState.Loader |
Settings ClassCastException Log1
Settings ClassCastException Log2
try-catch 异常报错的地方
try-catch 异常报错的地方
try-catch 异常报错的地方
三、IndexOutOfBoundsException 下标越界异常
List 在开发中经常会被用的,那么错误的使用下标,将会导致IndexOutOfBoundsException 越界异常。以下代码就会引起IndexOutOfBoundsException异常
IndexOutOfBoundsException 异常举例
Log 信息如下:
1 |
12-27 17:41:24.231 16891 16891 E AndroidRuntime: Caused by: java.lang.IndexOutOfBoundsException: Index: 0, Size: 0 |
IndexOutOfBoundsException Log分析
在使用时判断对象内容是否为0.
使用判断List 的size是否为0
四、ActivityNotFoundException
ActivityNotFoundException 常见于Eclipse 开发Android中,Android studio 已经帮忙自动生成Activity,以及布局文件。
主要原因是未在AndroidMainfest.xml文件中注册,如未注册,会引起app crash ,crash log如下:
ActivityNotFoundException: Unable to find explicit activity class
比如以下代码会引起此异常
Activity未在Androidmainfest.xml 中注册会引起ActivityNotFoundException
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? |
ActivityNotFoundException Log分析
在AndroidMainfest.xml中注册即可
四大组件一定,一定要在AndroidMainfest.xml 中注册
五、IllegalStateException
IllegalStateException 非法状态异常,是因为软件中代码状态非法导致的。
以下代码会引起IllegalStateException 。当Button控件声明android:onClick="IllegalStateException" 却未在Java代码中使用时,点击Button,就会出现此类异常。
IllegalStateException 代码举例
log信息如下:
1 |
12-27 16:07:41.158 1715 1715 E AndroidRuntime: FATAL EXCEPTION: main |
IllegalStateException Log截图
IllegalStateException 类异常很多,不同的代码会有不同的解决方案,上述举例解决方案如下
IllegalStateException
六、 ArrayIndexOutOfBoundsException 数组越界异常
数组在代码中经常被用到,当适用数组下标不当时,就会出现ArrayIndexOutOfBoundsException。比如数组长度为4,但你要引用下标为5的元素,这时候,就会异常crash。
1 |
public static void ArrayIndexOutOfBounds() {
|
ArrayIndexOutOfBoundsException 代码举例
Log信息如下:
1 |
12-27 17:51:15.420 19185 19185 E AndroidRuntime: Caused by: java.lang.ArrayIndexOutOfBoundsException: length=4; index=5 |
ArrayIndexOutOfBoundsException Log分析
1.正确使用数组下标
2.如果不确定数组长度,请先获取长度,然后在判断下标是否大于等于数组长度。
3.try-catch 抓住异常,防止crash,但不能从根本上解决问题。
七、SecurityException 安全异常
SecurityException 安全异常在Android 中也会经常发生,主要是Android 的安全机制原因造成的,为了管理应用获取手机的一些敏感信息,Android安全机制规定,必须在AndroidMainfest.xml文件中声明,并且,Android 6.0之后,获取手机敏感信息时候,需要动态申请权限,只有用户授权后才可以获取手机敏感信息。
获取手机的IMEI 号属于手机的敏感信息
1 |
/** |
获取手机IMEI号
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. |
SecurityException log 分析
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@5f3161e |
Log 分析
此异常经常发生在错误的解除绑定服务造成的,解决方法:
1.解除绑定服务之前,先判断是否绑定过,只有绑定过后才可以解绑
2.使用try-catch 抓取住异常
代码举例如下:
Service not registered 异常举例
九、BadTokenException 解决方案
1 |
03-12 14:55:13.734 5564 5564 E AndroidRuntime: FATAL EXCEPTION: main |
Android 8.0 之后如果要弹出系统弹窗,需要使用 TYPE_APPLICATION_OVERLAY以及
来进行系统弹窗,否则会报以下异常BadTokenException: Unable to add window android.view.ViewRootImpl$W@f652dba -- permission denied for window type 2003
系统弹窗,请用TYPE_APPLICATION_OVERLAY 替换之前的Windows Type。
1 |
Dialog mFMDialog = new AlertDialog.Builder(context) |
Google 官方链接如下:
Android 8.0 Alert 弹窗行为变更
Android 8.0 Alert 弹窗行为变更
参考文章:
https://www.jianshu.com/p/8c6beaccfdb9;
https://blog.csdn.net/weixin_44053242/article/details/99293108;
https://mp.weixin.qq.com/s?__biz=MzU4MTIzMjM3MA==&mid=2247485503&idx=5&sn=6e9eb15516f43f06bb14f7438591e2ea&scene=21#wechat_redirect
文章浏览阅读1.6k次。安装配置gi、安装数据库软件、dbca建库见下:http://blog.csdn.net/kadwf123/article/details/784299611、检查集群节点及状态:[root@rac2 ~]# olsnodes -srac1 Activerac2 Activerac3 Activerac4 Active[root@rac2 ~]_12c查看crs状态
文章浏览阅读1.3w次,点赞45次,收藏99次。我个人用的是anaconda3的一个python集成环境,自带jupyter notebook,但在我打开jupyter notebook界面后,却找不到对应的虚拟环境,原来是jupyter notebook只是通用于下载anaconda时自带的环境,其他环境要想使用必须手动下载一些库:1.首先进入到自己创建的虚拟环境(pytorch是虚拟环境的名字)activate pytorch2.在该环境下下载这个库conda install ipykernelconda install nb__jupyter没有pytorch环境
文章浏览阅读5.2k次,点赞19次,收藏28次。选择scoop纯属意外,也是无奈,因为电脑用户被锁了管理员权限,所有exe安装程序都无法安装,只可以用绿色软件,最后被我发现scoop,省去了到处下载XXX绿色版的烦恼,当然scoop里需要管理员权限的软件也跟我无缘了(譬如everything)。推荐添加dorado这个bucket镜像,里面很多中文软件,但是部分国外的软件下载地址在github,可能无法下载。以上两个是官方bucket的国内镜像,所有软件建议优先从这里下载。上面可以看到很多bucket以及软件数。如果官网登陆不了可以试一下以下方式。_scoop-cn
文章浏览阅读4.5k次,点赞2次,收藏3次。首先要有一个color-picker组件 <el-color-picker v-model="headcolor"></el-color-picker>在data里面data() { return {headcolor: ’ #278add ’ //这里可以选择一个默认的颜色} }然后在你想要改变颜色的地方用v-bind绑定就好了,例如:这里的:sty..._vue el-color-picker
文章浏览阅读640次。基于芯片日益增长的问题,所以内核开发者们引入了新的方法,就是在内核中只保留函数,而数据则不包含,由用户(应用程序员)自己把数据按照规定的格式编写,并放在约定的地方,为了不占用过多的内存,还要求数据以根精简的方式编写。boot启动时,传参给内核,告诉内核设备树文件和kernel的位置,内核启动时根据地址去找到设备树文件,再利用专用的编译器去反编译dtb文件,将dtb还原成数据结构,以供驱动的函数去调用。firmware是三星的一个固件的设备信息,因为找不到固件,所以内核启动不成功。_exynos 4412 刷机
文章浏览阅读2w次,点赞24次,收藏42次。Linux系统配置jdkLinux学习教程,Linux入门教程(超详细)_linux配置jdk
文章浏览阅读3.3k次,点赞5次,收藏19次。xlabel('\delta');ylabel('AUC');具体符号的对照表参照下图:_matlab微米怎么输入
文章浏览阅读119次。顺序读写指的是按照文件中数据的顺序进行读取或写入。对于文本文件,可以使用fgets、fputs、fscanf、fprintf等函数进行顺序读写。在C语言中,对文件的操作通常涉及文件的打开、读写以及关闭。文件的打开使用fopen函数,而关闭则使用fclose函数。在C语言中,可以使用fread和fwrite函数进行二进制读写。 Biaoge 于2024-03-09 23:51发布 阅读量:7 ️文章类型:【 C语言程序设计 】在C语言中,用于打开文件的函数是____,用于关闭文件的函数是____。
文章浏览阅读3.4k次,点赞2次,收藏13次。跟随鼠标移动的粒子以grid(SOP)为partical(SOP)的资源模板,调整后连接【Geo组合+point spirit(MAT)】,在连接【feedback组合】适当调整。影响粒子动态的节点【metaball(SOP)+force(SOP)】添加mouse in(CHOP)鼠标位置到metaball的坐标,实现鼠标影响。..._touchdesigner怎么让一个模型跟着鼠标移动
文章浏览阅读178次。项目运行环境配置:Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。项目技术:Springboot + mybatis + Maven +mysql5.7或8.0+html+css+js等等组成,B/S模式 + Maven管理等等。环境需要1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。_基于java技术的停车场管理系统实现与设计
文章浏览阅读3.5k次。前言对于MediaPlayer播放器的源码分析内容相对来说比较多,会从Java-&amp;gt;Jni-&amp;gt;C/C++慢慢分析,后面会慢慢更新。另外,博客只作为自己学习记录的一种方式,对于其他的不过多的评论。MediaPlayerDemopublic class MainActivity extends AppCompatActivity implements SurfaceHolder.Cal..._android多媒体播放源码分析 时序图
文章浏览阅读2.4k次,点赞41次,收藏13次。java 数据结构与算法 ——快速排序法_快速排序法