android日志系统提供了记录和查看系统调试信息的功能,日志都是从各个软件和一些系统的缓冲区中记录下来的,缓冲区可以通过logcat命令来进行查看和使用

开发者选项,有个选项叫做“日志记录器缓冲区大小”,默认是256K,日志是循环写入环形缓冲区的,在通常情况下,写满时最旧的日志会被删除已给新输出的日志留内存空间

1.缓冲区的类型
Android 日志系统为日志消息保留了多个循环缓冲区,不是所有的消息都被发送到默认缓冲区,要想查看这些附加的缓冲区,可以使用 -b选项,查看指定的缓冲区:

adb logcat [-b <buffer>]
buffer可以有如下选项:

    • Radio 参数可以抓取Android RIL层 ,查看log包含在通信系统的log,如蓝牙、wifi、打印.、网卡、3G、4G    命令:adb logcat -b radio
    • Events 查看事件相关的消息,比如启动应用,停止文件 事件.
    • Main 查看主缓冲区、所有Java层的log(默认缓冲区).
    • System 输出系统组件的log(默认缓冲区).

ps:默认使用 【adb logcat】会输出Main及System缓冲区的log信息。

加参数-v  time 可以显示每天记录的详细时间,如  adb logcat -b system -v time > D:\log.system.txt

2.认识输出日志信息

输出的日志信息格式如下图所示:

1)日志内容由五部分组成

大概就是显示:时间 、进程Id=1164、 线程Id=1181、优先级=D、标签(tag)=WindowManger : message

    1. 写下日志时的时间,如:08-11 09:45:35.209
    2. 优先级:日志的优先级从小到大为

V-Verbose(啰嗦,最低级别,开发调试时的一些详细信息,仅在开发中使用,不可在发布产品中输出)

D-Debug(调试,用于调试的信息,可以在发布产品中关闭,比较常见)

I-information(信息,一般提示性的消息)

W-warning(警告)

E-Error (错误,已经出现可影响运行的错误,比如应用crash时输出的日志)

S(无记载)

3.标签(tag),表明日志发起者和方便日志的过滤筛选,如上图中的SystemServer

4.PID(进程ID),如上图中的1760

5.正文,本日志的主体部分

2)过滤日志

如果要减少logcat 的输出日志,可以使用如上条件进行过滤、可用多个表达一起限制

过滤表达式的格式为:tag:prority (因为同一个tag可以有不同的优先级)

如:adb logcat ActivityManager:I MyApp:D *:S

备注1:仅用于输出标记为“ActivityManager”且优先级大于等于"I"和标记为“MyApp”,优先级大于等于"Debug"的日志。

备注2:*:S是用于设置ActivityManager:I MyApp:D输出的日志再次过滤 ,标记这些日志的优先级为S(即只输入ActivityManager:I MyApp:D日志,其他的不输出)

备注3:一般都会在过滤后加上*:S以输出符合指令的日志

adb logcat *:W  // "*"是指所有的tag, "*:W"是指输出所有的优先级为W以上的所有tag日志信息

可通过包名来过滤日志,

将程序运行在前台,通过命令查看应用包名称:adb shell dumpsys | findstr "mFocusedActivity"

3)分析日志异常情况

发生 crash 问题,搜索关键字 force finishing  (往上找日志:FATAL EXCEPTION—Force finish)

ANR(Application not responding)应用无响应,当应用操作一段时间内系统无法处理时,系统会弹出无响应的对话框。具体可以产看traces.txt文件,进行分析。

traces.txt文件是一个ANR记录文件,用于开发人员调试,目录位于/data/anr中
,无需root权限即可通过pull命令获取,下面的命令可以将traces.txt文件拷贝到当前目录下

通过ANR in 过滤数据 从上往下找数据

ANR需要提交的日志文件:logcat(从ANR in 开始+cpu使用之后)+Trace.txt(保存的是最后一次anr 的信息)

出现多次anr:将dropbox 下的data_app_anr 直接给开发人员

通过dropbox 收集一段时间内的异常信息(包括ANR)

/data/system/dropbox

Data_app 是第三方的app

App 发生异常

l  首先判断是崩溃还是无响应anr(根据对话框进行)

l  Adb logcat抓取日志文件 如果是ANR 取dropbox下面的data_app_anr

l  复现场景 复现步骤复现环境

logcat日志文件的更多相关文章

  1. adb 之日志文件分析(五)

    一,logcat日志文件 1,addroid日志系统提供了记录和查看系统调试信息的功能,日志都是从各种软件和一些系统的缓冲区(内存)中记录下来的,缓冲区可以通过logcat命令来查看和使用 2,在开发 ...

  2. android adb logcat获取日志文件

    一般情况,可以直接在电脑终端上输入logcat来查看手机运行日志,但是测试工作者为了抓取日志文件来给开发人员,需要把日志导出到特定文件中.如下文. 以小米1s手机为例 步骤1:打开第一个终端窗口 ad ...

  3. Android APP测试的日志文件抓取

         1    log文件分类简介 实时打印的主要有:logcat main,logcat radio,logcat events,tcpdump,还有高通平台的还会有QXDM日志 状态信息的有: ...

  4. Android中对Log日志文件的分析[转]

    一,Bug出现了, 需要“干掉”它 bug一听挺吓人的,但是只要你懂了,android里的bug是很好解决的,因为android里提供了LOG机制,具体的底层代码,以后在来分析,只要你会看bug, a ...

  5. 【Android】ADB常用指令与logcat日志(转)

    ADB命令简介 ADB是一个功能强大的命令行工具.通过它可以直接和模拟器或真机进行交互.它是一个具有客户端和服务器端的程序. 它主要由三个部分组成: 客户端,它运行在你的开发机上,你可以通过执行adb ...

  6. 分包收集 android 运行的 logcat 日志

    # -*- coding:utf-8 -*- import os import time from common import Common comm = Common() cmd = r'adb l ...

  7. 【Android】ADB常用指令与logcat日志

    ADB命令简介 ADB是一个功能强大的命令行工具.通过它可以直接和模拟器或真机进行交互.它是一个具有客户端和服务器端的程序. 它主要由三个部分组成: 客户端,它运行在你的开发机上,你可以通过执行adb ...

  8. 【android】[转]Android软件测试的日志文件抓取简介

    1    log文件分类简介 实时打印的主要有:logcat main,logcat radio,logcat events,tcpdump,还有高通平台的还会有QXDM日志 状态信息的有:adb s ...

  9. android抓取logcat日志的方法

    这几天帮忙测试一个APP,报告结果需要提交日志文件,于是百度了下安卓的获取日志方法,其实很简单,7个步骤搞定,下面把我的总结分享给大家. 1.下载adb工具包 https://pan.baidu.co ...

随机推荐

  1. Java 仓储模式

    使用的Spring boot +Jpa 项目层级: common里包含了model,以及一些viewModel等等 下面就是设计的仓储模式 先看下SysUser: @MappedSuperclass ...

  2. MongoDB使用固定集合

    MongoDB中的固定集合:大小是固定的,类似于循环队列,如果没有空间了,最老的文档会被删除以释放空间,新插入的会占据这块空间. 1.固定集合(oplog) oplog是一个典型的固定集合,因为其大小 ...

  3. mysql清除主从复制关系

    mysql清除主从复制关系 网页转自https://www.cnblogs.com/wjoyxt/p/5343662.html mysql主从复制中,需要将主从复制关系清除,需要取消其从库角色.这可通 ...

  4. Java Collection - 遍历map的几种方式

    作者:zhaoguhong(赵孤鸿) 出处:http://www.cnblogs.com/zhaoguhong/ 本文版权归作者和博客园共有,转载请注明出处 ---------------- 总结 如 ...

  5. SpringBatch批处理框架

    1.前言:本博客是对于刘相SpringBatch批处理框架的学习 1.1.参考网站:https://docs.spring.io/spring-batch/4.2.x/reference/html/i ...

  6. 欧拉定理+质因子分解+矩阵快速幂——cf1182E

    好题! /* gi=c^i * fi gi=gi-1 * gi-2 * gi-3 把g1,g2,g3质因数分解 g1=p1^e11 * p2^e12 * p3^e13 ... pk^e1k g2=p1 ...

  7. bzoj 1196: [HNOI2006]公路修建问题(二分+贪心)

    传送门 解题思路 看到最大,肯定要先想二分答案.二分之后首先从小到大枚举\(k\)个小于\(lim\)的所有一级公路,然后用并查集连到一起,然后就在剩下的里面从小到大找n-1-k个二级公路,模仿最小生 ...

  8. java接口的意义,为什么接口可以多继承,而类不可以?

    原文地址:http://www.cnblogs.com/yunxiblog/p/5240690.html java当中继承一个接口,要重写他的方法的话,那为什么还要多此一举的去实现一个接口呢? 直接把 ...

  9. Android Drawable 详解(教你画画!)

    参考 1.Android中的Drawable基础与自定义Drawable 2.android中的drawable资源 3.Android开发之Shape详细解读 Drawable分类 No xml标签 ...

  10. SpringBoot--Banner的定制和关闭

    SpringBoot项目启动的时候控制台会打印如下信息: 上面红色框框内的“SPRING BOOT”被称为Banner,意为横幅,默认会开启并在控制台打印,其实我们可以修改它的内容和样式,即定制:并选 ...