当前位置: 首页 > news >正文

系统开发必学技巧:安卓调试logcat/grep命令常用高阶技巧

背景:

在平常的安卓framework实战开发中经常会用到logcat来抓取分析相关的日志,同时也会结合grep进行过滤相关日志。这块我们平常使用的方式一般主要是如下几个:

# 查看不同缓冲区adb logcat -b main# 主缓冲区(默认)adb logcat -b radio# 无线/电话相关adb logcat -b events# 系统事件adb logcat -b crash# 崩溃日志adb logcat -b all# 所有缓冲区#一般如果要过滤#TAG过滤logcat -s TAG#grep过滤logcat|grepTAG

但是上面的这些基本命令其实在实际开发中是完全不够的,比如列举一个日志过滤场景:
需要过滤日志中多个关键字应该如何呢?
我们过滤命令是如下:

logcat|grepTAG

但是这里明显只会过滤出带有TAG的关键字的日志,还有TAG1,TAG2,TAG3这些关键字呢?
所以本文分析一些高阶常用的logcat和grep命令结合使用方法。

Logcat 高级过滤技巧

1. 按优先级过滤日志
通过设置优先级级别,仅显示特定级别的日志:

adb logcat *:W 仅显示WARN级别及以上的日志
  • 优先级从低到高:V(Verbose)、D(Debug)、I(Info)、W(Warning)、E(Error)、F(Fatal)。

2. 多条件组合过滤
结合标签和优先级进行精确过滤:

adb logcat MyApp:D System.err:W *:S
  • 显示MyApp标签的DEBUG及以上级别日志,System.err标签的WARN级别日志,其他标签静默(*:S)。

3. 时间范围过滤

# 显示最近N行adb logcat -t100# 最近100行# 显示特定时间后的日志adb logcat -t'01-15 14:30:00.000'# 显示日志文件中的特定时间段adb logcat -T'01-15 14:30:00.000'-t'01-15 15:00:00.000'

4.查看特定应用的日志(需先获取PID)

# 按进程ID过滤adb logcat --pid=1234# 按标签过滤并显示进程信息adb logcat|grep-E"\( *1234\)"adb shell pidof com.example.app adb logcat --pid=$(adb shell pidof com.example.app)

Grep 高级过滤技巧

1. 正则表达式匹配
使用-E启用扩展正则表达式:

adb logcat|grep-E'VDE]/(TAG1|TAG2)'
  • 匹配优先级为VDETAG1TAG2日志。

2. 忽略大小写
使用-i选项忽略大小写:

adb logcat|grep-i myapp
  • 匹配MyAppmyapp等大小写变体。

3. 显示前后行
显示匹配行的前后5行:

# 显示匹配行及上下文grep-B5"error"# 显示匹配前5行grep-A5"error"# 显示匹配后5行grep-C5"error"# 显示匹配前后各5行# 组合使用adb logcat|grep-B2 -A2"NullPointer"

4. 递归搜索文件
在当前目录及其子目录中搜索:

grep-r --color=auto'test'*
  • -r递归搜索,--color=auto高亮显示匹配内容。

5. 仅显示文件名
不显示匹配行,仅显示文件名:

grep-r -l'test'*
  • -l仅列出包含匹配行的文件名。

logcat和grep结合使用技巧

1. 过滤特定标签和优先级

adb logcat ActivityManager:I PowerManagerService:D *:S
  • 仅显示ActivityManager标签的INFO及以上级别日志,PowerManagerService标签的DEBUG及以上级别日志,其他标签静默。

2. 实时过滤特定日志

adb logcat|grep-E'MyApp|System.err'
  • 实时过滤包含MyAppSystem.err的日志。

这些技巧结合adb logcatgrep命令,能高效过滤和分析Android日志,帮助快速定位问题。

实时过滤并高亮

adb logcat|grep--color=auto -E"WARN|ERROR|FATAL"

3.日志中排除特定内容

# 排除特定内容adb logcat|grep-v"NoiseTag"# 排除多个 TAG,用 | 分隔adb logcat|grep-v -E"NoiseTag|AnotherTag|UselessTag"# 排除多个TAG日志adb logcat|grep-vE"NoiseTag|AnotherTag|UselessTag"
http://www.cnnetsun.cn/news/48924.html

相关文章:

  • Step-Audio 2系列深度实战指南:多模态音频理解的技术突破与应用全景
  • 量子计算终极指南:如何用Qiskit快速掌握量子编程的完整教程
  • React-chartjs-2 实战深度突破:从数据混沌到可视化洞察的架构思维
  • 22、LTSP 环境搭建与 Ubuntu 服务器安全指南
  • 23、Linux系统安全管理:sudo、AppArmor与SSH的深度解析
  • 智能中文对话系统完整构建指南:从零到一的5个关键步骤
  • Java泛型实战:类型安全与高效开发
  • 无需函数,教你快速分离Excel单元格中的文本和数字
  • 学术探索新航标:书匠策AI解锁毕业论文写作的“隐形导航仪”
  • 告别论文“缝合怪”:解锁书匠策AI,把信息碎片织成你的知识图谱
  • 学术迷航中的智能灯塔:书匠策AI如何重构毕业论文写作生态
  • 别再死磕论文了!你的毕业论文需要一个“科研副驾”
  • 当你的学术世界支离破碎,我借AI之手为它重绘版图
  • 论文焦虑终结者?揭秘「书匠策AI」如何用算法重构你的学术写作体验
  • 职场进阶:如何全面提升面试表现力?
  • 律师咨询|基于springboot + vue律师咨询系统(源码+数据库+文档)
  • Agent 通过Langchain实现网页检索功能
  • 终极指南:5分钟快速搭建个人作品集网站的完整解决方案
  • CogVideo革命性突破:2D视频秒变立体3D的智能转换技术
  • DeepLabCut实战进阶:从姿态估计到强化学习环境的深度配置指南
  • 终极游戏DLC解锁指南:三步免费解锁付费内容
  • SeedVR2 2.5.10全面评测:8GB显存也能玩转的AI视觉增强神器
  • PCSX2模拟器性能优化终极指南:从卡顿到流畅的完整解决方案
  • 告别卡顿:DBeaver性能优化终极指南
  • NetSonar网络诊断工具:快速定位网络问题的终极解决方案
  • 电子书格式不兼容 零门槛转换 一键搞定 电子书格式转换下载器
  • 『一键掌控』Defender Control:Windows安全防护的终极管理方案
  • 如何在3小时内构建28M微模型:数据预处理实战避坑指南
  • Wallpaper Engine壁纸下载器:5分钟学会轻松获取创意工坊动态壁纸
  • 250MB实现千亿级能力:腾讯混元0.5B重构边缘AI范式