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

ADB打印设备日志相关

1. 基础日志命令

# 实时打印全部设备日志
adb logcat# 保存完整日志到文件(带时间戳)
adb logcat -v time > full_log.txt# 仅保存崩溃日志
adb logcat -b crash > crash_log.txt# 仅保存ANR日志(应用无响应)
adb logcat -v time | grep "ANR" > anr_log.txt

2. 多设备操作

# 获取已连接设备列表
adb devices -l# 输出示例:
# List of devices attached
# emulator-5554device product:sdk_gphone_x86 model:Android_SDK_built_for_x86 device:generic_x86
# 5c1b5a3edevice usb:336592896X product:walleye model:Pixel_2 device:walleye# 获取设备序列号
adb get-serialno# 默认设备
adb -s emulator-5554 get-serialno# 指定设备# 指定设备执行命令
adb -s emulator-5554 logcat# 指定设备抓日志

3. 高级日志过滤

# 排除调试信息(只显示Error及以上级别)
adb logcat *:E# 按标签过滤日志
adb logcat -s AndroidRuntime# 仅显示运行时错误
adb logcat -s MyAppTag# 仅显示自定义标签日志# 按进程ID过滤
adb shell ps -A | grep "myapp"# 查找进程ID
adb logcat --pid=1234# 仅显示指定进程日志

4. 系统诊断命令

# 获取完整系统报告(包含所有日志和状态)
adb bugreport > system_report.zip# 提取ANR跟踪文件
adb pull /data/anr/traces.txt anr_traces.txt# 查看当前顶层Activity
adb shell dumpsys activity top | grep ACTIVITY
# 输出示例:ACTIVITY com.example.myapp/.MainActivity 12345abc pid=6789

5. 崩溃监控技巧

# 持续监控运行时崩溃
adb logcat -b main -b system -b crash | grep -E "FATAL|CRASH"# 监控Native崩溃信号
adb logcat | grep -E "SIGSEGV|SIGABRT|SIGILL"# 自动保存最新崩溃日志
while true; do
adb logcat -d -b crash > crash_$(date +%s).txt
sleep 5
done

安装与配置说明

Windows安装:

  1. 下载Platform-Tools
  2. 解压zip文件
  3. 添加路径到系统环境变量:我的电脑 > 属性 > 高级系统设置 > 环境变量
  4. 命令行验证:adb version

macOS/Linux安装:

# macOS
brew install android-platform-tools# Ubuntu/Debian
sudo apt install adb fastboot# 验证安装
adb --version

USB调试启用:

  1. 手机进入设置 > 关于手机
  2. 连续点击"版本号"7次启用开发者模式
  3. 返回设置 > 系统 > 开发者选项
  4. 启用"USB调试"和"USB安装"

提示:

  • 使用adb logcat -c清除旧日志
  • 崩溃日志保存在/data/tombstones/目录(需root)
  • 对于ANR问题,同时检查/data/anr/目录内容
  • 无线调试命令:adb tcpip 5555 && adb connect <设备IP>
http://www.lryc.cn/news/614439.html

相关文章:

  • 手机拍照识别中模糊场景准确率↑37%:陌讯动态适配算法实战解析
  • 用LaTeX优化FPGA开发:结合符号计算与Vivado工具链(二)
  • 大模型量化上溢及下溢解析
  • ESP32-menuconfig(4) -- Partition Table
  • Web Worker 性能革命:让浏览器多线程为您的应用加速
  • ChipCamp探索系列 -- 1. Soft-Core RISC-V on FPGA
  • 【10】C#实战篇——C# 调用 C++ dll(C++ 导出函数、C++导出类)
  • 华清远见25072班C语言学习day5
  • Advances and Challenges in Foundation Agents--Memory调研
  • WPF 双击行为实现详解:DoubleClickBehavior 源码分析与实战指南
  • 基于ffmpeg和rk3588的mpp编解码库多路融屏程序设计
  • 贝叶斯定理 vs 条件概率
  • Redis(⑤-线程池隔离)
  • 【从0到1制作一块STM32开发板】6. PCB布线--信号部分
  • React函数组件灵魂搭档:useEffect深度通关指南!
  • 如何实现在多跳UDP传输场景,保证单文件和多文件完整传输的成功率?
  • 三相交流电机旋转磁场产生原理
  • Django模型开发全解析:字段、元数据与继承的实战指南
  • Flutter开发 多孩子布局组件
  • [202403-B]算日期
  • 蓝桥杯----大模板
  • V4L2摄像头采集 + WiFi实时传输实战全流程
  • FreeRTOS入门知识(初识RTOS)(一)
  • Chat GPT5功能
  • 使用 Gulp 替换 XML 文件内容
  • 明厨亮灶场景下误检率↓76%:陌讯多模态融合算法实战解析
  • Ignite节点生命周期钩子机制详解
  • 基于Spring Boot的Minio图片定时清理实践总结
  • 如何使用Databinding实现MVVM架构
  • GPT5新功能介绍以及和其他模型对比