Android logcat命令详解

参考网址:https://www.cnblogs.com/JianXu/p/5468839.html

一、logcat命令介绍

二、logcat缓冲区

三、logcat命令参数

四、logcat格式化输出

五、logcat优先级

一、logcat命令介绍

1.android log系统

image

2.logcat介绍

logcat是android中的一个命令行工具,可以用于得到程序的log信息

log类是一个日志类,可以在代码中使用logcat打印出消息

  • 常见的日志纪录方法包括:

方法

描述

v(String,String) (vervbose)显示全部信息
d(String,String)(debug)显示调试信息
i(String,String)(information)显示一般信息
w(String,String)(waning)显示警告信息
e(String,String)(error)显示错误信息

例如:

 
  1. //开发过程中获取log

  2. Log.i("MyActivity","MyClass.getView() - get item number"+position);

  3. //adb获取log

  4. adb logcat

adb logcat输出的日志格式如下:

I/ActivityManager( 1754): Waited long enough for: ServiceRecord{2b24178c u0 com.google.android.gms/.checkin.CheckinService}

3.logcat命令格式

语法格式:

[adb] logcat [<option>] … [<filter – spec>] …

PC端使用:

adb logcat

shell模式下使用:

logcat

二、logcat缓冲区

1.缓冲区介绍

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

1)Radio:输出通信系统的log

2)System:输出系统组件的log

3)Event:输出event模块的log

4)Main:所有java层的log,遗迹不属于上面3层的log

缓冲区主要给系统组件使用,一般的应用不需要关心,应用的log都输出到main缓冲区中

默认log输出(不指定缓冲区的情况下)是输出System和Main缓冲区的log

2.缓冲区模型

image

3.获取缓冲区命令

参数

描述

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

4.实例

  1. adb logcat –b radio

  2. adb logcat –b system
  3. adb logcat –b events
  4. adb logcat –b main

三、logcat命令参数

1.参数说明

参数

描述

-b <buffer>加载一个可使用的日志缓冲区供查看,比如event和radio。默认值是main
-c清除缓冲区中的全部日志并退出(清除完后可以使用-g查看缓冲区)
-d将缓冲区的log转存到屏幕中然后退出
-f <filename>将log输出到指定的文件中<文件名>.默认为标准输出(stdout)
-g打印日志缓冲区的大小并退出
-n <count>设置日志的最大数目<count>,默认值是4,需要和-r选项一起使用
-r <kbytes>没<kbytes>时输出日志,默认值是16,需要和-f选项一起使用
-s设置过滤器
-v <format>设置输出格式的日志消息。默认是短暂的格式。支持的格式列表

一般长时间输出log的话建议-f,-n,-r三个参数连用,这样当一个文件日志输出满了之后可以马上在另一个中进行输出

2.实例

  1. //将缓冲区的log打印到屏幕并退出

  2. adb logcat -d

  3. //清除缓冲区log(testCase运行前可以先清除一下)

  4. adb logcat -c

  5. //打印缓冲区大小并退出

  6. adb logcat -g

  7. //输出log

  8. adb logcat -f /data/local/tmp/log.txt -n 10 -r 1

四、logcat格式化输出

1.参数说明

日志消息包含一个元数据字段,除了标签和优先级,您可以修改输出显示一个特定的元数据字段格式的消息。为此,您使用-v选项来指定一个支持的输出格式。一下为支持的格式:

格式

说明

brief显示优先级/标记和过程的PID发出的消息(默认格式)
process只显示PID
tag只显示优先级/标记
raw显示原始的日志消息,没有其他元数据字段
time调用显示日期、时间、优先级/标签和过程的PID发出消息
threadtime调用显示日期、时间、优先级、标签遗迹PID TID线程发出的消息
long显示所有元数据字段与空白行和单独的消息

当logcat开始,指定想要输出格式-v选项:

[adb] logcat [-v <format>]

adb logcat –v thread

只能指定一个输出格式-v

2.例子

image

五、logcat优先级

1.优先级语法

优先级使用字符标识,一下优先级从低到高

V –Verbose(最低优先级)

D – Debug

I – Info

W – Warning

E – Error

F – Fatal

S – Silent

为了减少不想要日志的输出,可以建立一个过滤器

过滤语法:tag:priority

 
  1. //过滤TAG为ActivityManager输出级别大于I的日志与TAG为MyApp输出级别大于D的日志

  2. adb logcat ActivityManager:I My App:D *:S

adb logcat *:W

设置过滤级别为W以上

如果用的比较多可以设置环境变量:

export ANDROID_LOG_TAGS="ActivityManager:I MyApp:D*:S"

  • 6
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
adb logcat是一个在移动端开发和测试中广泛使用的命令。它用于输出设备的日志,以便分析错误原因。adb logcat命令有多种常用的选项和过滤项可以使用。其中一些常用的选项包括: 1. "-s"选项:只显示指定标签的日志,例如"adb logcat -s SWVDEC"可以显示SWVDEC标签的日志。 2. "-v"选项:设置日志的输出格式,例如"adb logcat -v threadtime"可以查看日志的输出时间和线程信息。 3. "-c"选项:清空所有的日志缓存信息,例如"adb logcat -c"可以清空日志缓存。 4. "-d"选项:将缓存的日志输出到屏幕上,并且不会阻塞,例如"adb logcat -d"可以将缓存的日志输出到屏幕上。 5. "-t"选项:输出最近的几行日志,输出完毕后退出,不会阻塞,例如"adb logcat -t 5"可以输出日志缓冲区的最近5行日志。 6. "-g"选项:查看日志缓冲区的信息,例如"adb logcat -g"可以查看日志缓冲区的信息。 7. "-B"选项:以二进制形式输出日志,例如"adb logcat -B"可以以二进制形式输出日志。[2] adb logcat命令还可以通过使用管道和grep命令来过滤日志,输出指定标签的日志,并且可以将日志保存到文件中。例如,"adb logcat | grep -E “android|system” > /home/cherish/log.txt"可以过滤出带有"android"或者"system"标签的日志,并将其保存到文件中。另外,在Windows上不能使用grep命令,可以使用findstr命令代替。[1] 总之,adb logcat命令是一个非常有用的工具,可以帮助开发人员和测试人员分析设备的日志,定位和解决问题。[3]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值