adb logcat命令行用法

1 篇文章 0 订阅

adb logcat命令用于输出手机或模块器开机以及用户对手机/模拟器进行操作后生成的系统日志,最后显示的日志为用户最近操作记录的日志。

区别:
AS的logcat:需要打开IDE,运行程序才能打印日志。
adb logcat:设备连接成功后,直接在设备操作程序就可以打印日志,方便很多,同时有很多的筛选命令能够满足需求。

操作环境:Linux 终端

基本流程:
手机usb连接电脑
1.查看是否连接设备:adb devices
2.输入adb logcat -s MainActivity 表示过滤在TAG MainActivity中的所有日志,也可以输入其他的筛选命令
3.打开设备中要测试的程序
4.程序运行到log时,屏幕就会打印出对应日记
5.ctrl+c 结束当前输出。

adb logcat 命令格式 :
adb logcat [选项] [过滤项], 其中 选项 和 过滤项 是可选的;
选项解析 :
-s : 设置输出日志的标签, 只显示该标签的日志;
-f: 将日志输出到文件, 默认输出到标准输出流中, -f 参数执行不成功;
-r : 按照每千字节输出日志, 需要 -f 参数, 不过这个命令没有执行成功;
-n : 设置日志输出的最大数目, 需要 -r 参数, 这个执行 感觉 跟 adb logcat 效果一样;
-v : 设置日志的输出格式, 注意只能设置一项;
-c : 清空所有的日志缓存信息;
-d : 将缓存的日志输出到屏幕上, 并且不会阻塞;
-t : 输出最近的几行日志, 输出完退出, 不阻塞;
-g : 查看日志缓冲区信息;
-b : 加载一个日志缓冲区, 默认是 main, 下面详解;
-B : 以二进制形式输出日志;

日志的等级有小到大:
– V : Verbose (明细);

– D : Debug (调试);

– I : Info (信息);

– W : Warn (警告);

– E : Error (错误);

– F: Fatal (严重错误);

– S : Silent(Super all output) (最高的优先级, 可能不会记载东西);

代码中日志输出为

TAG="MainActivity"
Log.i(TAG, "cameraList: mCameraOrientation  " + mCameraOrientation);
Log.i(TAG, "cameraList: backFpsRanges" + Arrays.toString(FpsRanges));
Log.i(TAG, "cameraList: isFocusing" + f);

TAG="SavePhoto"
Log.d(TAG, "imageSaver: mImageFile  d" + mImageFile);
Log.i(TAG, "imageSaver: mImageFile  i" + mImageFile);
Log.e(TAG, "imageSaver: mImageFile  e" + mImageFile);

-s:设置过滤的标签;-v:设置日志输出格式;
如以下图:设置输出格式为 time,对标签SavePhoto进行筛选,只输出有SavePhoto的日志,MainActivity的不输出。

-v输出格式类型:
1.“time”:输出时间 日志等级/tag标签(进程ID):日志信息
在这里插入图片描述
2.“threadtime”:输出时间 进程ID 线程ID 日志等级 tag标签:日志信息
·在这里插入图片描述
3.“brief”:日志等级/tag标签(进程ID):日志信息
在这里插入图片描述
4.“process”:日志等级(进程ID) 日志信息
在这里插入图片描述
5.“tag”:日志等级/tag标签:日志信息
在这里插入图片描述
6.“thread”:日志等级(进程ID:线程ID) 日志信息

在这里插入图片描述
7.“raw”:日志信息
在这里插入图片描述
8.“long”:[输出时间 进程ID:线程ID 日志等级/tag标签]
日志信息
在这里插入图片描述

-s过滤多标签:
1.输出格式为“long”,过滤SavePhoto的D(包括D)以上的等级日志,即 D,I,W,E,F,S
当选为:E时,输出E等级标签
在这里插入图片描述
2.输出格式为“long”,同时过滤SavePhoto的I(包括I)以上的等级日志和MainActivity的E(包括E)以上的等级日志;
MainActivity标签的都是I等级,所以没有输出。
在这里插入图片描述

打印日志到本地:
adb logcat -v long -s SavePhoto >log.txt 打印日志到当前目录下的log.txt(没有就会创建,有则覆盖)

adb logcat -v long -s SavePhoto >/home/sfs/log.txt 指定路径/home/sfs/log.txt

清理日志缓存,
adb logcat -c 若想再查看日志需要重新打开程序.

过滤指定等级日志
adb logcat *:E

logcat中筛选多个关键字:
筛选AA,BB,CC关键字: ^(.(AA|BB|CC)).$
不想看到AA,BB,CC关键字: (.*[(AA|BB|CC)]).*$

参考链接:https://blog.csdn.net/tumuzhuanjia/article/details/39555445

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值