zoukankan      html  css  js  c++  java
  • android adb logcat详解(三)

    adb logcat命令获取Android设备上的log日志

    一、查看adb logcat 的帮助信息

    在命令行中输入adb logcat --help命令,就可以显示该命令的帮助信息;

    日志格式:

     其中选项和过滤想在中括号[]中,说明这是可选的;

    adb logcat [<option>] ... [<filter-spec>] ... 
    adb logcat [选项] [过滤项] 
    

    常用选项及参数说明:

    • adb logcat选项解析
      • -s:设置输出日志的标签,只显示该标签的日志
        • adb logcat -s System.out 输出标签"System.out"的日志信息
      • -f:将日志输出到文件,默认输出到标准输出流中,-f参数执行不成功;
        • adb logcat -f /sdcard/log.txt 
      • -r:按照每千节字输出日志,需要-f参数,不过这个命令没有执行成功;
      • -n:设置日志输出到最大数目,需要-r参数,这个执行感觉跟adb logcat 效果一样;
      • -v:设置日志到输出格式,注意只能设置一项;
        • adb logcat -v time 日期 时间 优先级/标签 (进程ID) : 进程名称 : 日志信息 
        • adb logcat -v brief 优先级/标签 (进程ID) : 日志信息
        • adb logcat -v process 优先级 (进程ID) : 日志信息
        • adb logcat -v tag 优先级/标签 : 日志信息
        • adb logcat -v raw 只输出日志信息, 不附加任何其他 信息, 如 优先级 标签等
        • adb logcat -v threadtime 日期 时间 进程 线程 优先级:日志信息
        • adb logcat -v long 日期 时间 进程ID : 线程ID 优先级/标签:日志信息
      • -c:清空所有到日志缓存信息;
        • adb logcat -c 可以将之前的日志信息清空,重新开始输出日志信息
      • -d:将缓存到日志输出到屏幕上,之后退出命令,并且不会阻塞;
      • -t:输出最近到几行日志,输出完退出,不阻塞;
        • adb logcat -t 5 输出最近的5行日志
      • -g:查看日志缓冲区信息;
        • adb logcat -g
        • wuhuaroudeMacBook-Pro:~ gokaniku$ adb logcat -g
          main: ring buffer is 256Kb (255Kb consumed), max entry is 5120b, max payload is 4068b
          system: ring buffer is 256Kb (237Kb consumed), max entry is 5120b, max payload is 4068b
          crash: ring buffer is 256Kb (0b consumed), max entry is 5120b, max payload is 4068b

      • -b:加载一个日志缓冲区,默认是main,下面详解;
      • -B:以二进制形式输出日志;
    • adb logcat过滤项解析,过滤格式:<tag>[:priority],标签:日志等级,默认过滤项是“*:I”
      • V:Verbose(明细)
      • D:Debug(调试)
      • I:Info(信息)
      • W:Warn(警告)
      • E:Error(错误)
      • F:Fatal(严重错误)
      • S:Silent(Super all output)(最高的优先级,可能不会记载东西)

     二、命令详解

    1. 过滤指定标签,指定等级

    格式:adb logcat [TAG:LEVEL][TAG:LEVEL]...

    标签TAG:在进行log输出时需要指定标签

    LEVEL:

    可以选择:[V D I W E S]中其中一个

    TAG:X 的作用为: 输出标签为TAG的log级别大于X的信息. 例如:

       adb logcat Test:I 

    输出 Test的I 和I 级别以上的log,包括 i, w, e

    注意:

    (1)可以指定多个[TAG:LEVEL ]

    (2) level : S 表示为不输出该标签的日志,应为没有大于S级别的日志了

    (3) [TAG:LEVEL ] 不会影响其他标签的日志, 所以如果要屏蔽其他log请使用 *:S

       adb logcat Test:I *:S

     2.-b<buffer>加载一个可使用到日志缓冲区供查看,默认值是main

      adb logcat -b radio//查看radio缓冲区

    • radio:过滤通信系统部分的log
    • main:所有java层的log 注意:它不包含其他缓冲区的java层
    • system:系统组件的log
    • events:event模块的log
    • crash:崩溃的log
    • kernel:内核日志 可以看到rc文件中服务启动情况
    • default:主要输出main,system,crash三个缓冲区中的日志
    • all:以上所有缓冲区的日志全部输出

    3. 查看手机启动时候的内核日志命令:adb shell dmesg

    4.采用grep正则表达式过滤

    • grep正则表达式参见grep与正则表达式
      • adb logcat | grep -E '^[VDE]/(TAG1|TAG2)'

    5.在同时输出到屏幕和文件tee

    • 想要把日志保存到文件,如果采用IO重定向,就无法输出到屏幕, 针对这个问题可以采用 tee命令
      • adb logcat | grep -E '^[VDE]/(TAG1|TAG2)' | tee my.log

    三、使用管道过滤日志

    1.过滤固定字符串

    描述:过滤固定字符串 : 只要命令行出现的日志都可以过滤, 不管是不是标签;

    格式: adb logcat | grep TrafficMonitor 

    2.过滤字符串忽略大小写:adb logcat | grep -i trafficmonitor

    注意:如果不加"-i"输出日志为空

    3.使用正则表达式匹配

    分析日志 : 该日志开头两个字符是 "V/", 后面开始就是标签, 写一个正则表达式 "^..ActivityManager", 就可以匹配日志中的 "V/ActivityManager" 字符串;

    正则表达式过滤日志: 使用上面的正则表达式组成命令 adb logcat | grep "..ActivityManager"

     四、常用查看日志命令总结

    >adb logcat -v time *:E > F:/logcat.log

    • 通过进程id查看日志
      • 1.查看进程id:adb shell ps | grep "com.xxxx.xxxxx"
      • 2.adb logcat -s 29269
    • 通过应用名称查看日志
      • adb logcat | grep --color=auto -i  "com.xxxx.xxxxx"
    • 通过过滤指定标签查看日志
      • adb logcat -v time HwUidTcpMonitor:I *:S
  • 相关阅读:
    写爬虫,怎么可以不会正则呢?
    从 Scrapy 学习模块导入技巧
    博客已搬家至CSDN
    更改JDK默认编码,解决DBeaver乱码问题
    【2020面试】- Java中常见集合的默认大小以及扩容机制
    【2020面试】- CAS机制与自旋锁
    【2020面试】- filter和interceptor的区别
    【20k中级开发】-面试题201117
    【开发笔记】
    RPC 调用和 HTTP 调用的区别
  • 原文地址:https://www.cnblogs.com/helloTerry1987/p/11069148.html
Copyright © 2011-2022 走看看