adb logcat调试中常用的命令介绍

摘要:
日志是从各种软件和一些系统缓冲区中记录的,可以通过logcat命令查看和使用。adblogcat命令的格式:adblogcat[options][filter items]。选项和筛选器项在括号[]中,表示它们是可选的。有许多adblogcat调试命令不容易记住。以下是对Android Dapk项目调试中常用的logcat命令的介绍,以方便Android Dapk的开发和调试。接下来,将详细描述logcat的过滤项。使用logcat命令将日志信息输出到文本文档:adblogcat vtime˃filenamelogadblokcat stag˃filename。log adblogcat*:E˃文件名。日志adblogcat|grep“info”˃文件名。log注意:filename.log的存储路径。

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

adb logcat 命令格式 : adb logcat [选项] [过滤项], 其中 选项 和 过滤项 在 中括号 [] 中, 说明这是可选的。


adb logcat 调试命令繁多,不易记忆,下面结合Android apk工程调试中常用的logcat命令进行介绍,以利于Android apk的开发与调试。

其中几个比较常用命令:

  • adb logcat -c                                          --清除所有以前的日志
  • adb logcat -s tag_name                      --设置过滤选项,仅输出标签为tag_name的日志
  • adb logcat -v format                              --设置日志的输出格式。

adb logcat -v time                                      --显示格式 "日期 时间 优先级 / 标签 (进程ID) : 进程名称 : 日志信息 "

adb logcat -v thread                                  --显示格式 " 优先级 ( 进程ID : 线程ID) 标签 : 日志内容 "

adb logcat -v brief                                      --默认的日志格式" 优先级 / 标签 (进程ID) : 日志信息 "

adb logcat -v process                               --显示格式 " 优先级  (进程ID)   日志信息 "

adb logcat -v tag                                        --显示格式 " 优先级 / 标签 : 日志信息"

adb logcat -v raw                                       --显示格式只输出日志信息, 不附加任何其他 信息, 如 优先级 标签等,

adb logcat -v long                                     --显示格式 " [ 日期 时间 进程ID : 线程ID 优先级 / 标签] 日志信息 "

  •  adb logcat -t n                                       --设置日志输出的最大数目

adb logcat -t 5               --显示最近的5行日志


在进行Android apk 调试时,往往需要查看某些与apk相关的日志信息,因此需要进行过滤以获取简明有效的信息。接下来对logcat的过滤项进行详细说明。

过滤项格式

<tag>[:过滤项格式 : <tag>[:priority] ,标签:日志等级          默认的日志过滤项是 " *:I "

日志等级(priority)有:

  • V : Verbose (明细);
  • D : Debug (调试);
  • I : Info (信息);
  • W : Warn (警告);
  • E : Error (错误);
  • F : Fatal (严重错误);
  • S : Silent(Super all output) (最高的优先级, 可能不会记载东西);

接下来举例说明:

1、过滤指定等级日志

使用 adb logcat *:E 命令, 显示 Error 以上级别的日志。

2、过滤指定标签等级日志

     使用 adb logcat WifiHW:D *:S 命令进行过滤;

 -- 命令含义 : 输出10条日志, 日志是 标签为 WifiHW, 并且优先级 Debug(调试) 等级以上的级别的日志;

 --注意 *:S : 如果没有 *S 就会输出错误;

3、可以同时设置多个过滤器

使用adb logcat WifiHW:D dalvikvm:I *:S 命令, 输出 WifiHW 标签 的 Debug 以上级别 和 dalvikvm 标签的 Info 以上级别的日志;


为了更为精确的获取调试的信息,还可以使用管道过滤日志

过滤固定字符串

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

-- 命令adb logcat | grep Wifi ;

命令说明:在日志中过滤出有字符串“Wifi”的日志进行显示。


使用logcat命令将日志信息输出至文本文档中:

  adb logcat -v time > filename.log

  adb logcat -s tag > filename.log

  adb logcat *:E > filename.log

  adb logcat | grep "info" > filename.log

注意:filename.log的存储路径。




免责声明:文章转载自《adb logcat调试中常用的命令介绍》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇okio:定义简短高效每日学习心得:SQL查询表的行列转换/小计/统计(with rollup,with cube,pivot解析)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Android开发模拟器启动失败的解决方法

1. 错误提示信息  错误大概意思:连接到adb(android debug bridge)出现了一个严重的错误,你必须重启adb和Eclipse工具,请确保在位置……adb工具被执行了。 adb:是sdk提供的工具,在android-sdk-windowsplatform-tools目录下,通过adb可以连接到android手机或模拟器。像91手机...

Android O : DNS列表获取及IPv4/IPv6优先级修改

一、Android应用获取有线网络DNS列表 /** * 获取DNS列表 */ private List<String> getDnsList() { List<String> dnsList = new ArrayList(); if (this.mIEthern...

FreeRTOS系列第20篇---FreeRTOS信号量API函数

FreeRTOS的信号量包括二进制信号量、计数信号量、相互排斥信号量(以后简称相互排斥量)和递归相互排斥信号量(以后简称递归相互排斥量)。我们能够把相互排斥量和递归相互排斥量看成特殊的信号量。 信号量API函数实际上都是宏。它使用现有的队列机制。这些宏定义在semphr.h文件里。假设使用信号量或者相互排斥量。须要包括semphr.h头文件。 二进制信...

adb(16)-查看实时资源占用情况top

  命令: adb shell top 输出示例: User 0%, System 6%, IOW 0%, IRQ 0% User 3 + Nice 0 + Sys 21 + Idle 280 + IOW 0 + IRQ 0 + SIRQ 3 = 307 PID PR CPU% S #THR VSS RSS PCY UID...

尝鲜党:Nexus5、6刷安卓M教程

说明:   进入recovery的命令:adb reboot recovery        进入bootloader的命令:adb reboot bootloader 概述 F:Nexus5AndroidMhammerhead-MPZ44Q>fastboot flash bootloader bootloader bootlo ader-hamm...

关于WinForm/Web如何使用缓存Cach

Cache 的绝对到期与滑动到期 绝对到期:设置绝对过期时间 到了指定时间以后会失效。(类似Cookie机制) 相对到期也称滑动到期:设置相对过期时间 指定时间内无访问会失效。(类似Session机制) HttpRuntime.Cache与HttpContext.Current.Cache 为同一个对象HttpRuntime.Cache.Add 存在相同...