Android 缓存日志(Logcat)导出与分析全攻略

Android 缓存日志(Logcat)导出与分析全攻略

为什么要导出缓存日志?

  • 当遇到隐形的症状(崩溃、异常)时,方便事后排查
  • 网络掉线或 USB 断开时依然可用
  • 设备端缓存日志可用于异常回溯分析

按需过滤导出

1. 按进程(PID)过滤

bash 复制代码
adb logcat -d --pid=<pid> -v threadtime > app.log
缓冲区类型 命令示例 用途
崩溃日志 adb logcat -b crash > crash.log 未捕获异常
系统事件 adb logcat -b events > events.log 系统 UI 事件
Radio adb logcat -b radio > radio.log 网络/通信问题

按日志级别过滤

bash 复制代码
adb logcat -d -v threadtime *:E > errors.log

日志级别说明:

  • Verbose:全部日志
  • Debug:调试信息
  • Info:普通信息
  • Warning:警告
  • Error:错误
  • Fatal:致命错误

按关键字过滤

bash 复制代码
adb logcat -d -v threadtime | grep "NullPointer" > crash.log

验证导出结果

bash 复制代码
# 查看日志总行数
wc -l log_2025-08-08.log

# 查看前20行
head -n 20 log_2025-08-08.log

自动化示例

1. 一键导出当前前台应用日志

bash 复制代码
pkg=$(adb shell dumpsys window | grep mCurrentFocus | awk -F'/' '{print $1}' | awk '{print $NF}')
adb logcat -d -v threadtime --pid=$(adb shell pidof $pkg) > ${pkg}_$(date +%F_%H-%M-%S).log

2. 崩溃日志自动抓取器

bash 复制代码
while true; do
  if adb logcat -d -b crash | grep -q "FATAL EXCEPTION"; then
    ts=$(date +%F_%H-%M-%S)
    adb logcat -d -v long -b crash > crash_${ts}.log
    echo "崩溃日志已保存:crash_${ts}.log"
    break
  fi
  sleep 5
done

常见问题与优化技巧

问题 解决方案
Insufficient permissions 授予日志访问权限或获取 root
缓存覆盖 提前导出,增大缓存区大小
断连 保存到 /sdcard 后再拉取

乱码解决

bash 复制代码
adb logcat -d | iconv -f utf-8 -t utf-8//IGNORE > clean.log

最佳实践

  1. 测试阶段全程后台记录:

    bash 复制代码
    adb logcat -v threadtime -f /sdcard/full.log &
  2. 发现问题立即 dump 缓存

  3. 结合 bugreport 获取更全面的诊断信息

相关推荐
诸神黄昏EX15 小时前
Android Build系列专题【篇四:编译相关语法】
android
雨白17 小时前
优雅地处理协程:取消机制深度剖析
android·kotlin
leon_zeng017 小时前
更改 Android 应用 ID (ApplicationId) 后遭遇记
android·发布
2501_9160074719 小时前
iOS 混淆工具链实战,多工具组合完成 IPA 混淆与加固(iOS混淆|IPA加固|无源码混淆|App 防反编译)
android·ios·小程序·https·uni-app·iphone·webview
Jeled21 小时前
Retrofit 与 OkHttp 全面解析与实战使用(含封装示例)
android·okhttp·android studio·retrofit
creator_Li1 天前
缓存行Cache Line
缓存
ii_best1 天前
IOS/ 安卓开发工具按键精灵Sys.GetAppList 函数使用指南:轻松获取设备已安装 APP 列表
android·开发语言·ios·编辑器
2501_915909061 天前
iOS 26 文件管理实战,多工具组合下的 App 数据访问与系统日志调试方案
android·ios·小程序·https·uni-app·iphone·webview
limingade1 天前
手机转SIP-手机做中继网关-落地线路对接软交换呼叫中心
android·智能手机·手机转sip·手机做sip中继网关·sip中继
RainbowC01 天前
GapBuffer高效标记管理算法
android·算法