ADB打印设备日志相关

1. 基础日志命令

bash 复制代码
# 实时打印全部设备日志
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. 多设备操作

bash 复制代码
# 获取已连接设备列表
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. 高级日志过滤

bash 复制代码
# 排除调试信息(只显示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. 系统诊断命令

bash 复制代码
# 获取完整系统报告(包含所有日志和状态)
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. 崩溃监控技巧

bash 复制代码
# 持续监控运行时崩溃
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安装:

bash 复制代码
# 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>
相关推荐
流星白龙4 小时前
【MySQL高阶】21.撤销表空间,撤销日志
android·mysql·adb
流星白龙8 小时前
【MySQL高阶】22.双写缓冲区,重做日志
android·mysql·adb
unicrom_深圳市由你创科技9 小时前
MySQL 慢查询日志深度分析:从 “识别慢 SQL” 到 “定位瓶颈根因”
sql·mysql·adb
musk12121 天前
永久开启 ADB 无线调试
adb
流星白龙2 天前
【MySQL高阶】20.InnoDB 磁盘文件
android·mysql·adb
yun呐2 天前
mysql数据库误删恢复
数据库·mysql·adb
废弃的小码农2 天前
APP测试--adb使用介绍
python·测试工具·adb
Database_Cool_2 天前
AI Agent 混合检索选型:阿里云 AnalyticDB MySQL 向量+全文一站式方案
android·adb
musk12123 天前
adb 控制显示 隐藏 导航栏 顶部状态栏
adb
小镇敲码人3 天前
MySQL事务介绍
android·数据库·mysql·adb