一,logcat日志文件

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

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

  3. logcat 日志是以 beginning of xxx 开头的

  4,logcat缓冲区:android log输出量很大,特别是通信系统的log,因此adroid把log输出到不同的缓冲区,目前定义了4个log的缓冲区:

    radio:输出通信系统的log       通信系统如:蓝牙,wifi,3g、4g等

    system:输出系统组件的log      系统组件的权限比较高,和系统相关的都会产生日志

    events: 输出event模块的log      这个是事件模块,只有是手机对手机的操作都会产生事件

    main : 所有java层的log    只要是java语言编写的,都是产生log,他不属于上面的3层内容

    默认log输出(不指定缓冲区的情况下)是输出到system和main缓冲区的log

  5,抓取通信设备的log:  adb logcat -b radio > d:\test\radio.log   如果不加-b 会默认抓取main日志

  6,抓取main模块的日志:adb logcat > d:\test\main.log  这里抓取的日志不显示时间,那么怎么显示时间呢?用如下命令

    adb logcat -v time > d:\test\main_time.log

    

  7,日志的输出格式:由五部分组成,如图:

      

      a,写下日志的时间,如:04-03 13:58:17.146

      b,优先级,在android中,日志的优先级从低到高分以下几种

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

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

          I--info(信息,一般是提示性的信息)

          W--Warning(警告)

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

      c,标签(tag),表明日志发起者和方便日志的过滤筛选,如图中所示

      d,PID(进程ID),如图中所示4513

      e,正文,本日志的主体内容

      每一行的日志都由这些内容组成

   8,崩溃事件,在手机的体现为:

      很抱歉,“xxx”已经停止运行了------因为没有相应的app复现,所以只能手写,无截图

      这是崩溃,不是闪退,闪退没有提示框,都是crash 错误

      我们可以把日志打印出来:adb logcat -v time > > d:\test\main_crash.log

      在日志中我们可以搜索EXCEPTION这个关键字,用来找到具体错误的内容

      

   9,anr事件,在手机上的体现为:

      

    说明:anr全名是application not responding,也就是应用无响应,当操作在一段时间内系统无法处理时,系统层面会弹出上图的ANR对话框

       1,为用户在主线程长时间被阻塞时提供处理交互,提高用户体验

       2,android系统一种自身检测机制

    日志:adb logcat -v time >d:\test\main_anr.log

    定位日志:搜索ANR in  如图

    

    下面还有load:负载情况

    接着下面是cpu的使用率

    

    

    这里的日志给开发还不能够定位问题,开发 要定位问题就找到方法调用栈,那么这里并没有方法调用栈,不过通过这里可以了解是否CPU原因产生的

    在这个日志中我们可以看到下图的输出:  

    

    这说明anr的日志在系统的/data/anr/traces.txt目录下,通过这个命令就可以看tracse.txt中的日志,但是这里并不全,而且还非常多

    

    那么我们可以使用adb pull 命令把让拉取出来

    

    在这个日志中可能和adb logcat出现时间差,如果日志在3s内,就没问题,如果时间太长,就是需要重新找自己需要的日志,为什么时间会有差别,是因为adb logcat和main模块两个是不同的模块,不会同步

    在traces.txt日志中我们可以搜索TIMED_WAIT,就可以找到方法调用栈,这不是我们可以分析的,直接给开发就可

    

    所以要提交bug,需要提交logcat文件和tracse文件,tracse这个文件只会保留最新的anr信息,新的anr信息会把原来的anr信息覆盖掉,所以我们在测试的时候,如出现多次anr信息,我们就要用到dropbox

     我们可以使用adb shell 进入到android系统中,然后执行cd /data/system/dropbox 进入到dropbox中

    

    我们可以通过adb pull 把这些文件都拉取出来分析,这里既可以分析anr,也可以分析crash,万能的

    我们可以通过时间来判断哪些是先产生的,哪些是后产生的

    

    

      

    

  

adb 之日志文件分析(五)的更多相关文章

  1. [转载]mysql慢日志文件分析处理

    原文地址:mysql慢日志文件分析处理作者:maxyicha mysql有一个功能就是可以log下来运行的比较慢的sql语句,默认是没有这个log的,为了开启这个功能,要修改my.cnf或者在mysq ...

  2. /VAR/LOG/各个日志文件分析

     /VAR/LOG/各个日志文件分析 author:headsen  chen    2017-10-24   18:00:24 部分内容取自网上搜索,部分内容为自己整理的,特此声明. 1.   /v ...

  3. Android ANR log trace日志文件分析

      版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/qq_25804863/article/ ...

  4. Linux日志文件分析

    ---恢复内容开始--- 日志保存位置 默认 var/log目录下 主要日志文件 内核及公共消息日志:message 计划任务日志:cron 系统殷桃日志:demsg 邮件系统日志:maillog 用 ...

  5. IIS 日志文件分析

    先安装下文参考资料中的log parser studio 然后就可以针对日志文件进行sql语句的查询了. 各页面访问量排行 ) FROM '[LOGFILEPATH]' where cs-uri-st ...

  6. Hadoop日志文件分析系统

    Hadoop日志分析系统 项目需求: 需要统计一下线上日志中某些信息每天出现的频率,举个简单的例子,统计线上每天的请求总数和异常请求数.线上大概几十台 服务器,每台服务器大概每天产生4到5G左右的日志 ...

  7. 【app】Appium日志文件分析

    Appium在和客户端及手机端进行通讯的时候会输出很多日志,可以通过点击主面板的Get Raw Logs得到其原始日志: 现在我们另存到其他路径,并且以notepad工具打开进行查看 Appium日志 ...

  8. Linux系统——日志文件

    日志文件的分类 (1)内核及系统日志 由系统服务rsyslog管理,根据去主配置文件/etc/rsyslog.conf中的设置决定将内核消息及各种系统程序消息记录到什么位置. /etc/rsyslog ...

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

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

随机推荐

  1. Spring Cloud 是什么

    概念定义 Spring Cloud 是一个服务治理平台,提供了一些服务框架.包含了:服务注册与发现.配置中心.消息中心 .负载均衡.数据监控等等. Spring Cloud 是一个微服务框架,相比 D ...

  2. 从0开发3D引擎(十二):使用领域驱动设计,从最小3D程序中提炼引擎(第三部分)

    目录 上一篇博文 继续实现 实现"DirectorJsAPI.init" 实现"保存WebGL上下文"限界上下文 实现"初始化所有Shader&quo ...

  3. 7-43 jmu-python-字符串异常处理 (20 分)

    输入一行字符串及下标,能取出相应字符.程序能对不合法数据做相应异常处理. 输入格式: 行1:输入一字符串 行2:输入字符下标 输出格式: 下标非数值异常,输出下标要整数 下标越界,输出下标越界 数据正 ...

  4. SpringBoot整合Swagger2案例,以及报错:java.lang.NumberFormatException: For input string: ""原因和解决办法

    原文链接:https://blog.csdn.net/weixin_43724369/article/details/89341949 SpringBoot整合Swagger2案例 先说SpringB ...

  5. 用vue开发一个公众号商城SPA——1.前期准备和写页面

    使用vue开发公众号商城 第1篇记录项目准备.搭建,写页面遇到第问题以及总结,持续更新 公司最近接了个商城项目,包括PC端商城.微信公众号网页商城.后台管理系统.这几天在做微信公众号商城,又新接触了很 ...

  6. python学习(二)之turtle库绘图

    今天是三月七号,也就是女生节,或者女神节.不知道你是不是有自己喜欢的女孩子,在这里你可以用turtle库绘制一朵玫瑰花,送给你喜欢的姑娘.(拉到最后有惊喜哦)但在画这朵玫瑰花之前,先来一个基础的图形, ...

  7. OpenCV3入门(十三)图像运动模糊

    1.原理 运动模糊产生: 由于相机传感器或物体相对运动, 按快门瞬间造成图像产生运动模糊. 在用摄像机获取景物图像时,如果在相机曝光期间景物和摄像机之间存在相对运动,例如用照相机拍摄快速运动的物体,或 ...

  8. 如何使用Kibana

    目录 前言 一.安装 二.加载自定义索引 三.如何搜索数据 四.如何切换中文 五.如何使用控制台 六.可视化图表 七.使用仪表盘 前言 Kibana 是为 Elasticsearch设计的开源分析和可 ...

  9. Vue2.0 【第一季】第6节 v-model指令

    目录 Vue2.0 [第一季] 第6节 v-model指令 第6节 v-model指令 一.一个最简单的双向数据绑定代码: 二.修饰符 三.文本区域加入数据绑定 四.多选按钮绑定一个值 五.多选绑定一 ...

  10. jupyter 安装问题 building 'zmq.libzmq' extension error: Microsoft Visual C++ 14.0 is required. Get it with "Microsoft Visual C++ Build Tools": http://landinghub.visualstudio.com/visual-cpp-build-tools

    1.用pip install jupyter 安装到一半就报错 错误提示: building 'zmq.libzmq' extension error: Microsoft Visual C++ 14 ...