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

相关文章

Linux grep 命令的使用指南

《Linuxgrep命令的使用指南》本文给大家介绍Linuxgrep命令的使用指南,包括基础搜索语法、实践指南,感兴趣的朋友跟随小编一起看看吧... 目录linux grep 命令全面使用指南一、基础搜索语法1. 基本文本搜索2. 多文件搜索二、常用选项详解1. 输出控制选项2. 上下文控制选项三、正则表达

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按

Spring Security6.3.x的使用指南与注意事项

《SpringSecurity6.3.x的使用指南与注意事项》SpringSecurity6.3.1基于现代化架构,提供简洁配置、增强默认安全性和OAuth2.1/OIDC支持,采用Lambda... 目录介绍基础配置 (Servlet 应用 - 使用 Lambda DSL)关键配置详解(Lambda DS

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

sqlite3 命令行工具使用指南

《sqlite3命令行工具使用指南》本文系统介绍sqlite3CLI的启动、数据库操作、元数据查询、数据导入导出及输出格式化命令,涵盖文件管理、备份恢复、性能统计等实用功能,并说明命令分类、SQL语... 目录一、启动与退出二、数据库与文件操作三、元数据查询四、数据操作与导入导出五、查询输出格式化六、实用功

Python虚拟环境与Conda使用指南分享

《Python虚拟环境与Conda使用指南分享》:本文主要介绍Python虚拟环境与Conda使用指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python 虚拟环境概述1.1 什么是虚拟环境1.2 为什么需要虚拟环境二、Python 内置的虚拟环境工具

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. 基础操作模