Android log 日志分析
一. Log 日志中 Bug 类型
- 程序异常强制关闭:
Force Close,Fatal - 程序无响应:
Application Not Response,ANR(应用无响应)。一般是主线程超时无响应造成的。ANR类型有:keyDispatchTimeout(Activity):5秒无响应位于
ActivityManagerService.java类中// How long we wait until we timeout on key dispatching.
static final int KEY_DISPATCHING_TIMEOUT = 5*1000;
BroadcaseTimeout(Receiver):10秒无响应ServiceTimeout(Service):20秒无响应
ANR产生原因:- 在
UI线程做了耗时操作。比如在Activity中做了超过 5 秒无响应的耗时操作,比如文件读写,数据库读写,就会出现ANR
- 在
- ANR 避免:
- 不要在
UI线程做耗时操作。
- 不要在
一. log 日志文件的位置
- 可以通过在
application中实现接口:UncaughtExceptionHandler, 在实现的 ·uncaughtException()· 方法中把产生的log保存到本地。
二. log 日志文件的结构
三. log 日志中 bug 的查找和分析
日志文件关键字
Force Close:FatalApplication Not Response:ANR
查看 Log 基本步骤
- 如果是
ANR问题,在日志文件中搜索ANR,快速定位到关键事件信息。 - 如果是
Force Close或其他异常退出,搜索FATAL,快速定位到关键事件信息。 - 定位到关键事件信息后,查看信息是否明确,如何不明确的话,查看具体的进程和线程跟踪的日志,来定位 bug
- 如果是
Force Close快速定位案例出现了
Force Close的情况,搜索关键字FATAL,得到以下Log。10-18 14:36:35.197 16078 16078 E AndroidRuntime: FATAL EXCEPTION: main 10-18 14:36:35.197 16078 16078 E AndroidRuntime: Process: cc.lijingbo.crashhandler, PID: 16078 10-18 14:36:35.197 16078 16078 E AndroidRuntime: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.CharSequence android.widget.TextView.getText()' on a null object reference 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at cc.lijingbo.crashhandler.MainActivity$1.onClick(MainActivity.java:23) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at android.view.View.performClick(View.java:5232) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at android.view.View$PerformClick.run(View.java:21289) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at android.os.Handler.handleCallback(Handler.java:739) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:95) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at android.os.Looper.loop(Looper.java:168) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:5885) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:797) 10-18 14:36:35.197 16078 16078 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:687) 10-18 14:36:35.207 1187 17570 E ActivityManager: App crashed! Process: cc.lijingbo.crashhandler 10-18 14:36:35.207 1187 17570 W ActivityManager: Force finishing activity cc.lijingbo.crashhandler/.MainActivity
看到因为
NullPointerException造成的。
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.CharSequence android.widget.TextView.getText()' on a null object reference然后下一句提示项目的代码出错的地方:
at cc.lijingbo.crashhandler.MainActivity$1.onClick(MainActivity.java:23),在MainActivity的onClick方法的第23行源码
public class MainActivity extends AppCompatActivity {private TextView tv1;
private TextView tv2; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv1 = (TextView) findViewById(R.id.tv1);
tv1.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(MainActivity.this, tv2.getText().toString(), Toast.LENGTH_SHORT).show();
}
});
}
}
可以看到是因为使用
Toast的时候,tv2没有初始化,造成的空指针,把tv2初始化就可以了。
ANR快速定位案例
四. adb logcat 的学习和使用
- 抓取设备中日志到指定目录
- adb logcat >crash.log
参考:
Logcat 官网语法: https://developer.android.google.cn/studio/command-line/logcat.html#Syntax
Logcat 的使用:https://developer.android.google.cn/studio/debug/am-logcat.html
Analyze a Stack Trace: https://developer.android.google.cn/studio/debug/stacktraces.html
studio debug: https://developer.android.google.cn/studio/debug/index.html
如何分析解决 ANR : http://blog.csdn.net/dadoneo/article/details/8270107
Android log 日志分析的更多相关文章
- (转)DB2 db2diag.log 日志分析
DB2 db2diag.log 日志分析 原文:http://blog.csdn.net/lyjiau/article/details/52129997 db2diag.log是用来记录DB2数据库运 ...
- [日志分析] Access Log 日志分析
0x00.前言: 如何知道自己所在的公司或单位是否被入侵了?是没人来“黑”,还是因自身感知能力不足,暂时还没发现?入侵检测是每个安全运维人员都要面临的严峻挑战.安全无小事,一旦入侵成功,后果不堪设想. ...
- Android Log日志文件的分析、查看
Log 在android中的地位非常重要,要是作为一个android程序员不能过分析log这关,算是android没有入门吧 . 下面我们就来说说如何处理log文件 什么时候会产生log文件呢 ?一般 ...
- Android log日志
LOG是用来记录程序执行过程的机制,它既可以用于程序调试,也可以用于产品运营中的事件记录.在Android系统中,提供了简单.便利的LOG机制,开发人员可以方便地使用. androidsdk中提供了l ...
- 27、android log日志
一.记住 加写sd卡权限 二.代码 package com.example.logtest; import java.io.File; import java.io.IOException; impo ...
- nginx acces.log日志分析
1,统计各访问IP的总数 awk '{if($9>0 && $9==200 && substr($6,2)== "GET") a[$1]++} ...
- Android ANR从原理到日志分析,记下来就够了
站在巨人的肩膀上可以看的更远 做一个优秀的搬运工 Android 彻底理解安卓应用无响应机制 Android ANR日志分析全面解析 优秀的文章不可独享,要扩散,要做好笔记,哈 <沁园春长沙&g ...
- Android Native/Tombstone Crash Log 详细分析(转)
转自:http://weibo.com/p/230418702c2db50102vc2h Android 虽然已经有好几年了,但是NDK的开放速度却非常缓慢,所以目前网络上针对对Android Nat ...
- Android输出日志Log类并保存到文件中
android.util.Log常用的方法有以下5个: Log.v() Log.d() Log.i() Log.w() 以及 Log.e().根据首字母分别对应VERBOSE,DEBUG,INFO,W ...
随机推荐
- 〖Network〗一行命令创建 http-server
一行命令启动http-server总结:1. python2.x python2 -m SimpleHTTPServer 8000 2. python3.x python -m http.server ...
- RPC远程调用概念 && demo实例
RPC是指远程过程调用,直观说法就是A通过网络调用B的过程方法. 也就是说两台serverA.B,一个应用部署在Aserver上,想要调用Bserver上应用提供的函数/方法,因为不在一个内存空间,不 ...
- springMVC自定义方法属性解析器
使用场景例子: 用户登陆系统一般会往Session里放置一个VO对象,然后在controller里会来获取用户的userId等信息. 之前的写法是:@SessionAttributes配合@Model ...
- stm32点亮LED 测试代码及目录结构
. main.c - 使用PB12, PB13, PB14, PB15, PB5, PB6, PB7 这七个PB口点亮LED. 注意PB3和PB4是特殊口, 直接调用无效. #include &quo ...
- Git 经常使用命令合集
====== Git 经常使用命令合集 ====== === 1.Git 文档 === Git 中文文档观看地址:http://git.oschina.net/progit/ === ...
- android开发学习---基础知识学习、如何导入已有项目和开发一个电话拨号器
一.基础知识点学习 1.Android体系结构 如图所示,android 架构分为三层: (1)最底层是linux内核,主要是各种硬件的驱动,如相机驱动(Camera Driver),闪存驱动(Fl ...
- Linux主要shell命令详解(上)
[摘自网络] kill -9 -1即实现用kill命令退出系统 Linux主要shell命令详解 [上篇] shell是用户和Linux操作系统之间的接口.Linux中有多种shell,其中缺省使用的 ...
- Centos7-Lvs+Keepalived架构
Centos7-Lvs+Keepalived架构 LVS+Keepalived 介绍 1 . LVS LVS 是一个开源的软件,可以实现 LINUX 平台下的简单负载均衡. LVS 是 Lin ...
- webpack window 使用sass来编译css样式
1.执行安装: npm install sass-loader --save-dev (此处不行的话就换上npm install node-sass) 2.稍微修改一下config,删掉我们先前添加的 ...
- VM页面中遍历枚举类
1)自定义的枚举类如下所示: public enum BusType { MID_SMALL(1, "中小件"), FRESH(2, "生鲜"), GLOBAL ...