Logcat使用指南

2024-06-12 16:58
文章标签 使用指南 logcat

本文主要是介绍Logcat使用指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Logcat使用指南


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

推荐进入的方法是: 
adb shell 回车 
logcat xxxx

logcat的“选项”:

  • "-s"选项 : 设置输出日志的标签, 只显示该标签的日志; 
  • "-v"选项 : 设置日志的输出格式, 注意只能设置一项; "-c"选项 : 清空所有的日志缓存信息; 
  • "-d"选项 : 将缓存的日志输出到屏幕上, 并且不会阻塞; "-t"选项 : 输出最近的几行日志, 输出完退出, 不阻塞; "-g"选项 : 查看日志缓冲区信息; 
  • "-b"选项 : 加载一个日志缓冲区, 默认是 main;
  • "-B"选项 : 以二进制形式输出日志; 
 
  1. @Override
  2. protected void onCreate(Bundle savedInstanceState) {
  3. super.onCreate(savedInstanceState);
  4. setContentView(R.layout.activity_main);
  5. Log.d(TAG, "onCreate: debug");
  6. Log.i(TAG, "onCreate: info");
  7. Log.e(TAG, "onCreate: error");
  8. }

1. 操作符:-s: 
logcat -s ddd (筛选ddd标签的内容) 
结果:

shell@ha3g:/ $ logcat -s ddd
--------- beginning of system
--------- beginning of main
D/ddd     ( 7506): onCreate: debug
I/ddd     ( 7506): onCreate: info
E/ddd     ( 7506): onCreate: error

这里继续操作,如果出现了ddd标识的log,那么仍旧会继续显示。ctrl+c 可以让其中断。

2. 操作符:-g 
logcat -g 查看log缓冲区 
结果:

130|shell@ha3g:/ $ logcat -g
main: ring buffer is 2Mb (414Kb consumed), max entry is 5120b, max payload is 4076b
system: ring buffer is 256Kb (66Kb consumed), max entry is 5120b, max payload is 4076b

3. 操作符:-d 
logcat -d 一次性显示之前的日志内容,显示完毕后就结束停止了。这里我利用-s的组合进行筛选之前被ddd标记的log,输出结果后终端:

shell@ha3g:/ $ logcat -d -s ddd
--------- beginning of system
--------- beginning of main
D/ddd     ( 7506): onCreate: debug
I/ddd     ( 7506): onCreate: info
E/ddd     ( 7506): onCreate: error

这里可以选择缓冲区类型,规则是这样的:logcat -d [缓冲区类型]。 
比如上面没有加类型参数,所以显示了一个system和main,缓冲区有: 
system缓冲区 - 与系统相关的日志信息; 
radio缓冲区 - 广播电话相关的日志信息; 
events缓冲区 - 事件相关的日志信息; 
main缓冲区 - 主的缓冲区,上面显示的就是main缓冲区中的内容。上面的命令和下面的等价:

logcat -s ddd -d main

130|shell@ha3g:/ $ logcat -s ddd -d main
--------- beginning of main
--------- beginning of system
D/ddd     ( 7506): onCreate: debug
I/ddd     ( 7506): onCreate: info
E/ddd     ( 7506): onCreate: error

4. 操作符:-c 
清空之前的所有log,和as中log面板中的垃圾桶是一个作用。 
logcat -c

5. 操作符:-v 
logcat -v 设置log的格式。这里的格式只能设置下列的某一种,不可设置多种格式。

1.time 添加log的时间,注意这里的时间没有年份。

130|shell@ha3g:/ $ logcat -v time -d -s ddd
--------- beginning of system
--------- beginning of main
12-10 16:49:33.731 D/ddd     ( 7506): onCreate: debug
12-10 16:49:33.731 I/ddd     ( 7506): onCreate: info
12-10 16:49:33.731 E/ddd     ( 7506): onCreate: error

2.brief 默认的log输出样式,上文中的展示的都是这种格式。

shell@ha3g:/ $ logcat -v brief -d -s ddd
--------- beginning of system
--------- beginning of main
D/ddd     ( 7506): onCreate: debug
I/ddd     ( 7506): onCreate: info
E/ddd     ( 7506): onCreate: error

3.thread 带(进程id:线程id)的log信息:

shell@ha3g:/ $ logcat -v thread -d -s ddd
--------- beginning of system
--------- beginning of main
D( 7506: 7506) onCreate: debug
I( 7506: 7506) onCreate: info
E( 7506: 7506) onCreate: error

4.tag 仅仅带有tag的log信息:

shell@ha3g:/ $ logcat -v tag -d -s ddd
--------- beginning of system
--------- beginning of main
D/ddd     : onCreate: debug
I/ddd     : onCreate: info
E/ddd     : onCreate: error

5.long 完全体的log信息:

130|shell@ha3g:/ $ logcat -v long -d -s ddd
--------- beginning of system
--------- beginning of main
[ 12-10 16:49:33.731  7506: 7506 D/ddd      ]
onCreate: debug
[ 12-10 16:49:33.731  7506: 7506 I/ddd      ]
onCreate: info
[ 12-10 16:49:33.731  7506: 7506 E/ddd      ]
onCreate: error

6.raw 精简样式,仅仅输出info信息,连tag都没有:

130|shell@ha3g:/ $ logcat -v raw -d -s ddd
--------- beginning of main
--------- beginning of system
onCreate: debug
onCreate: info
onCreate: error

7.process 优先级样式,这个样式的tag在最后:

shell@ha3g:/ $ logcat -v process -d -s ddd
--------- beginning of main
--------- beginning of system
D( 7506) onCreate: debug  (ddd)
I( 7506) onCreate: info  (ddd)
E( 7506) onCreate: error  (ddd)

6.操作符 -t 
输出最近的n条log信息,输出后中断命令立刻结束。 
logcat -t 1000 (输出最近的1000条信息) 
测试:

shell@ha3g:/ $ logcat -d -t 1000 -s ddd
--------- beginning of system
--------- beginning of main
D/ddd     ( 7506): onCreate: debug
I/ddd     ( 7506): onCreate: info
E/ddd     ( 7506): onCreate: error

过滤选项

其实在上面我们就已经用过了过滤选项-s了,他可以用来过滤某个标签,下面详细说下具体的过滤规则。 
可以过滤的选项,级别,tag,关键字。

1.级别 
V : Verbose (明细); 
D : Debug (调试); 
I : Info (信息);  
W : Warn (警告); 
E : Error (错误); 
F : Fatal (严重错误); 
S : Silent(Super all output) (最高的优先级, 记录前所未有的错误); 
此外,如果你查看的级别为d,那么d,i,w,e..的高级别log都能被看到,原则是低级别可以看到高级别的信息,高级别看不到低级别的信息。

过滤级别的写法:logcat *:级别,比如:logcat *:E 或locat *:e (不区分大小写)

shell@ha3g:/ $ logcat *:E
--------- beginning of main
E/MultiWindowConverter( 3016): getApplicationName is error:Starting kale.myapplication
E/PersonaManagerService( 3016): inState():  stateMachine is null !!
E/ddd     ( 7506): onCreate: error

上面的*:E中的星号表示通配符,可以写任何tag,比如:ddd

2.tag

130|shell@ha3g:/ $ logcat ddd:E *:S
--------- beginning of main
--------- beginning of system
E/ddd     ( 7506): onCreate: error

这里需要注意,输入了tag后就必须添加 *:S的尾缀,否则出错。

我们仍旧可以扩展这个格式,进行多个级别和tag的筛选 
logcat ddd:E ddd:D *:S (过滤tag为ddd的两个级别的日志)

130|shell@ha3g:/ $ logcat ddd:E ddd:D *:S
--------- beginning of main
--------- beginning of system
D/ddd     ( 7506): onCreate: debug
I/ddd     ( 7506): onCreate: info
E/ddd     ( 7506): onCreate: error

3.关键字 
我们可以通过grep来过滤关键字,这样更加灵活。 
写法:logcat | grep 关键字 
比如:logcat | grep ddd(只能识别小写的ddd) 
logcat | grep i ddd(无论是DDD,ddD,ddd...都可以被识别)

130|shell@ha3g:/ $ logcat -d | grep ddd
D/ddd     ( 7506): onCreate: debug
I/ddd     ( 7506): onCreate: info
E/ddd     ( 7506): onCreate: error
D/MainActivity( 7506): ║ ddd                                                   

grep是支持正则表达式的,所以可以用正则的写法。

用代码执行上面的命令行

AndroidManifest.xml添加读取权限  

清除日志

 
  1. try {
  2. Runtime.getRuntime().exec("logcat -c");
  3. } catch(Exception e) {}
  4. // 获取日志
  5. try {
  6. ArrayList<String> commandLine = new ArrayList<String>();
  7. commandLine.add( "logcat");
  8. commandLine.add( "-d");
  9. commandLine.add( "-v");
  10. commandLine.add( "time");
  11. commandLine.add( "-s"); //-s其实就是*:S
  12. commandLine.add( "tag:W");
  13. Process process = Runtime.getRuntime().exec( commandLine.toArray( new String[commandLine.size()]));
  14. BufferedReader bufferedReader = new BufferedReader( new InputStreamReader(process.getInputStream()), 1024);
  15. String line = bufferedReader.readLine();
  16. while ( line != null) {
  17. log.append(line);
  18. log.append("\n")
  19. }
  20. } catch ( IOException e) {
  21. }

其实就是执行了 logcat -d -v time -s tag:W 这个命令

这篇关于Logcat使用指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1054801

相关文章

Java JSQLParser解析SQL的使用指南

《JavaJSQLParser解析SQL的使用指南》JSQLParser是一个Java语言的SQL语句解析工具,可以将SQL语句解析成为Java类的层次结构,还支持改写SQL,下面我们就来看看它的具... 目录一、引言二、jsQLParser常见类2.1 Class Diagram2.2 Statement

正则表达式r前缀使用指南及如何避免常见错误

《正则表达式r前缀使用指南及如何避免常见错误》正则表达式是处理字符串的强大工具,但它常常伴随着转义字符的复杂性,本文将简洁地讲解r的作用、基本原理,以及如何在实际代码中避免常见错误,感兴趣的朋友一... 目录1. 字符串的双重翻译困境2. 为什么需要 r?3. 常见错误和正确用法4. Unicode 转换的

Python Selenium动态渲染页面和抓取的使用指南

《PythonSelenium动态渲染页面和抓取的使用指南》在Web数据采集领域,动态渲染页面已成为现代网站的主流形式,本文将从技术原理,环境配置,核心功能系统讲解Selenium在Python动态... 目录一、Selenium技术架构解析二、环境搭建与基础配置1. 组件安装2. 驱动配置3. 基础操作模

Spring Validation中9个数据校验工具使用指南

《SpringValidation中9个数据校验工具使用指南》SpringValidation作为Spring生态系统的重要组成部分,提供了一套强大而灵活的数据校验机制,本文给大家介绍了Spring... 目录1. Bean Validation基础注解常用注解示例在控制器中应用2. 自定义约束验证器定义自

Python Websockets库的使用指南

《PythonWebsockets库的使用指南》pythonwebsockets库是一个用于创建WebSocket服务器和客户端的Python库,它提供了一种简单的方式来实现实时通信,支持异步和同步... 目录一、WebSocket 简介二、python 的 websockets 库安装三、完整代码示例1.

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

2025最新版Python3.13.1安装使用指南(超详细)

《2025最新版Python3.13.1安装使用指南(超详细)》Python编程语言自诞生以来,已经成为全球最受欢迎的编程语言之一,它简单易学易用,以标准库和功能强大且广泛外挂的扩展库,为用户提供包罗... 目录2025最新版python 3.13.1安装使用指南1. 2025年Python语言最新排名2.

Deepseek使用指南与提问优化策略方式

《Deepseek使用指南与提问优化策略方式》本文介绍了DeepSeek语义搜索引擎的核心功能、集成方法及优化提问策略,通过自然语言处理和机器学习提供精准搜索结果,适用于智能客服、知识库检索等领域... 目录序言1. DeepSeek 概述2. DeepSeek 的集成与使用2.1 DeepSeek API

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资