赞
踩
1、ANR in - ANR问题的通用标签
2、NullPointerException - 空指针异常
3、IndexOutOfBoundsException - 数组、集合等越界
4、IllegalArgumentException - 不合法的参数异常,可能是使用函数或者启动服务等等参数设置错误等
5、java.lang.IllegalStateException - “非法的状态”,可能是对于API的时序使用错误,比如start后立即 stop,其实异步的Start还没有初始化完成,但是你瞬间就Stop了,也可能造成状态错乱等错误。
6、java.lang.StackOverflowError 堆栈溢出错误。当一个应用递归调用的层次太深而导致堆栈溢出时抛出该错误,(死循环了等)
7、ArithmeticException - 算术运算异常
8、NumberFormatException - 数字格式异常
9、UnsupportedOperationException - 不支持的操作异常
10、SecurityException - 安全异常,比如Android 6.0以上App原生开发需要动态权限申请,但是你没申请就使用了等,会提示这类错误。 当以上特定错误不出现得时候,可以查一些共通的标签:
12、java.lang.RuntimeException - 各种JAVA异常的通用标签。
13、beginning of crash - 奔溃log一般起始标识
14、Input dispatching timed out - 这个log是安卓源码中输出的(ActivityManagerService当中的ANR),引起的原因是页面启动的时序中包含耗时较长的逻辑,需要优化从application启动到activity的resume(显示给用户)整个流程的时序,这类问题一般已经不是解bug的问题了,如果这种压力测试的错误必解,可能需要重构部分时序了(很多应用启动慢和启动卡顿等也是启动时序中太多耗时代码导致的,部分不重要的初始化逻辑还是要放到子线程去处理的)。
start U0 可以查找activity启动的log
am_、wm_ 可以查找activityManager相关的log
三、Log分析和使用总结整理:
1、通用的Log标识需要了解,拿到Log文件后找不到自己模块的Log,也可以找找自己的包名、主Activity名、原生抛出的通用Crash标识等,Crash问题可能是我们调用其他模块函数引起的,也可能是别人调用我们函数引起的,基于通用的Log分析定位大部分的还是能够定位出原因的,基于以上分析如果还是无法定位,根据现象分析等可以酌情给可能引起问题的类添加Log,再去依赖测试去重新截取Log等,尽量不要出现测试反复截取无Log的现象。
2、另外,自己模块的Log或者错误Log没有出现不能就一定能排除自己的问题,很可能也是因为自己模块的主线程耗时代码太多,导致主线程阻塞了,所以其他模块调用你的函数或者进程间通信无法打印出Log,所以分析Log还是要深入一些,复杂问题具体问题具体分析。
ps: 关于Android应用启动慢的偶现问题,可以通过"start U0|am_|wm_"等标签去查启动log am_restart_activity和am_stop_activity能够看出APP切换的时间,细致查一下启动慢的原因,耗时再哪里. 另外,如图am_low_memory出现代表系统内存不足,也会导致应用启动慢。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。