一. Log 日志中 Bug 类型

  1. 程序异常强制关闭: Force Close ,Fatal
  2. 程序无响应: 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 的查找和分析

  1. 日志文件关键字

    • Force CloseFatal
    • Application Not Response : ANR
  2. 查看 Log 基本步骤

    1. 如果是 ANR问题,在日志文件中搜索ANR,快速定位到关键事件信息。
    2. 如果是Force Close或其他异常退出,搜索FATAL,快速定位到关键事件信息。
    3. 定位到关键事件信息后,查看信息是否明确,如何不明确的话,查看具体的进程和线程跟踪的日志,来定位 bug
  3. 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),在 MainActivityonClick 方法的第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 初始化就可以了。

  4. 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 日志分析的更多相关文章

  1. (转)DB2 db2diag.log 日志分析

    DB2 db2diag.log 日志分析 原文:http://blog.csdn.net/lyjiau/article/details/52129997 db2diag.log是用来记录DB2数据库运 ...

  2. [日志分析] Access Log 日志分析

    0x00.前言: 如何知道自己所在的公司或单位是否被入侵了?是没人来“黑”,还是因自身感知能力不足,暂时还没发现?入侵检测是每个安全运维人员都要面临的严峻挑战.安全无小事,一旦入侵成功,后果不堪设想. ...

  3. Android Log日志文件的分析、查看

    Log 在android中的地位非常重要,要是作为一个android程序员不能过分析log这关,算是android没有入门吧 . 下面我们就来说说如何处理log文件 什么时候会产生log文件呢 ?一般 ...

  4. Android log日志

    LOG是用来记录程序执行过程的机制,它既可以用于程序调试,也可以用于产品运营中的事件记录.在Android系统中,提供了简单.便利的LOG机制,开发人员可以方便地使用. androidsdk中提供了l ...

  5. 27、android log日志

    一.记住 加写sd卡权限 二.代码 package com.example.logtest; import java.io.File; import java.io.IOException; impo ...

  6. nginx acces.log日志分析

    1,统计各访问IP的总数 awk '{if($9>0 && $9==200 && substr($6,2)== "GET") a[$1]++} ...

  7. Android ANR从原理到日志分析,记下来就够了

    站在巨人的肩膀上可以看的更远 做一个优秀的搬运工 Android 彻底理解安卓应用无响应机制 Android ANR日志分析全面解析 优秀的文章不可独享,要扩散,要做好笔记,哈 <沁园春长沙&g ...

  8. Android Native/Tombstone Crash Log 详细分析(转)

    转自:http://weibo.com/p/230418702c2db50102vc2h Android 虽然已经有好几年了,但是NDK的开放速度却非常缓慢,所以目前网络上针对对Android Nat ...

  9. Android输出日志Log类并保存到文件中

    android.util.Log常用的方法有以下5个: Log.v() Log.d() Log.i() Log.w() 以及 Log.e().根据首字母分别对应VERBOSE,DEBUG,INFO,W ...

随机推荐

  1. java中经常使用的快捷键

    Eclipse(MyEclipse) 经常使用快捷键Eclipse 的编辑功能很强大.掌握了 Eclipse 快捷键功能,能够大大提高开发效率. Eclipse中有例如以下一些和编辑相关的快捷键.1. ...

  2. JVM——字节码增强技术简介

    Java字节码增强指的是在Java字节码生成之后,对其进行修改,增强其功能,这种方式相当于对应用程序的二进制文件进行修改.Java字节码增强主要是为了减少冗余代码,提高性能等. 实现字节码增强的主要步 ...

  3. ACE中对于不同类型数据的最大值最小值管理ACE_Numeric_Limits

    对于不同类型的变量,这里定义了其最大最小值来提供给ACE_Utils等使用 template <typename T> struct ACE_Numeric_Limits; // ---- ...

  4. 【Java】监控远程服务器JVM

    今天在用JMeter进行测试的时候,发现线程并发量到50的时候会导致阻塞情况,于是需要监控远程JVM,那么如何监控远程JVM呢? 首先,找到启动计量引擎的sh文件,例如我目前的计量引擎启停文件为str ...

  5. DLib库Base64编解码示例

    代码 #include <iostream> #include <fstream> #include <sstream> #include <string&g ...

  6. Spring Cloud Edgware Release Notes

    Spring Cloud Edgware builds on Spring Boot 1.5.x. Renamed starters A number of starters did not foll ...

  7. 微软微服务架构eShopOnContainers

    为了推广.Net Core,微软为我们提供了一个开源Demo-eShopOnContainers,这是一个使用Net Core框架开发的,跨平台(几乎涵盖了所有平台,windows.mac.linux ...

  8. mysql5.6特殊字符问题

    问题描述: 在搭建redis监控cache-cloud软件,发现对建立cache-cloud的库,无法删除 drop database cache-cloud; 很奇怪..... 问题解决: 百思不得 ...

  9. 通过Intent传递对象

    BluetoothDevice device = data.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE); 在蓝牙开发中,通过intent(data ...

  10. MATLAB 的函数句柄

    MATLAB 的函数句柄: 1.何为函数句柄? 函数句柄也是MATLAB中的一种常见的数据类型, 它的地位类似于其它计算机语言里的函数对象(Javascript,Python),函数指针(C++),或 ...