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

Android ADB 常用指令全解析

ADB(Android Debug Bridge)是 Android 开发和测试不可或缺的调试工具,它建立了电脑与 Android 设备之间的通信桥梁,通过命令行指令可实现对设备的全方位控制。掌握 ADB 指令能大幅提升开发效率,解决各类调试难题。本文系统整理了 ADB 的常用指令,按功能分类详解,包含使用场景与实战示例,助你快速成为 ADB 高手。

一、ADB 基础与环境配置

什么是 ADB?

ADB 是 Android SDK 中的一个命令行工具,全称为 Android Debug Bridge,本质是一个客户端 - 服务器程序,包含三个核心组件:

  • 客户端:运行在开发机上,负责接收用户输入的指令(如命令行输入adb命令)
  • 守护进程(daemon):以adbd进程形式运行在 Android 设备后台,负责执行客户端发送的指令
  • 服务器:运行在开发机后台的adb进程,负责管理客户端与设备守护进程的通信,协调多个客户端与设备的连接

ADB 最初由 Google 在 Android 1.0 时代推出,设计初衷是解决开发过程中 "设备 - 开发机" 交互的痛点。它基于 TCP/IP 协议实现通信,默认通过 USB 接口传输数据,也支持无线连接模式。经过十余年演进,ADB 已从简单的调试工具发展为集设备管理、应用调试、系统控制于一体的全能工具,成为 Android 开发生态中不可或缺的基础设施。

其核心价值体现在:

  • 打破应用沙箱限制,允许开发机直接操作设备底层资源
  • 提供统一的命令接口,兼容从手机到智能手表的全系列 Android 设备
  • 支持跨平台操作(Windows/macOS/Linux),保障开发环境一致性

ADB 的工作原理

ADB 的通信流程遵循典型的 C/S 架构:

1.当用户在终端输入adb命令时,客户端会向本地 ADB 服务器发送请求(默认端口 5037)

2.服务器检查是否已与目标设备建立连接,若未连接则尝试通过 USB 或网络发现设备

3.服务器将指令转发至设备上的adbd守护进程

4.守护进程执行指令并将结果通过服务器返回给客户端

5.客户端将结果显示在终端界面

这种分层架构的优势在于:

  • 支持多客户端同时连接(如同时打开多个命令行窗口操作设备)
  • 服务器自动管理设备连接状态,无需用户手动维护通信链路
  • 指令执行与结果返回的异步处理,提升复杂操作的效率

环境配置步骤

1.安装 Android SDK Platform Tools

  • 官网下载对应系统的 Platform Tools(包含 ADB 工具)
  • 解压后将路径添加到系统环境变量(Windows 的 PATH 或 macOS/Linux 的.bashrc/.zshrc)
  • 验证安装:打开终端输入adb version,显示版本信息即表示安装成功

2.设备调试模式配置

  • 开启设备 "开发者选项":连续点击系统版本号 7 次(不同品牌路径可能不同)
  • 启用 "USB 调试" 选项(Android 11 + 需额外开启 "无线调试" 权限)
  • 首次连接时,设备会弹出 "USB 调试授权" 窗口,勾选 "始终允许此计算机" 以避免重复授权

3.连接设备

  • 有线连接:用 USB 线连接设备与电脑,通过adb devices确认连接状态
  • 无线连接:需先通过 USB 配置(见后文详解),适合需要摆脱线缆束缚的场景

4.确认连接状态

adb devices

正常情况下会显示设备序列号及状态:

  • device:连接正常,可执行指令
  • offline:设备已连接但未响应(通常需重启 ADB 或设备)
  • unauthorized:未授权调试权限(需在设备上确认授权)

ADB 的安全机制

为保护用户隐私与设备安全,ADB 采用多层次安全措施:

1.调试授权机制:首次连接新设备时必须通过设备端确认,防止未授权计算机访问设备

2.权限分级:普通 ADB 指令受限于设备用户权限,敏感操作(如修改系统文件)需 root 权限

3.无线调试加密:Android 11 + 的无线调试采用配对码验证,避免局域网内的恶意连接

4.沙箱隔离:非 root 状态下,ADB 无法直接访问其他应用的私有目录,保障数据隔离

这些机制平衡了开发便利性与设备安全性,尤其在 Android 6.0 引入运行时权限后,ADB 的权限管控更加严格,部分系统级操作需通过pm grant显式授权。

二、设备管理指令

查看设备信息

指令

功能

示例

adb devices

列出所有连接的设备

adb devices -l(显示详细信息)

adb get-serialno

获取设备序列号

adb -s 设备号 get-serialno(指定设备)

adb shell getprop ro.product.model

查看设备型号

-

adb shell getprop ro.build.version.release

查看 Android 系统版本

-

adb shell wm size

查看屏幕分辨率

-

adb shell wm density

查看屏幕密度

-

实战示例

# 查看所有设备详细信息
adb devices -l# 查看设备型号和Android版本
adb shell getprop ro.product.model
adb shell getprop ro.build.version.release

设备连接控制

指令

功能

示例

adb kill-server

停止 ADB 服务器

-

adb start-server

启动 ADB 服务器

-

adb reboot

重启设备

adb reboot recovery(重启到恢复模式)

adb connect <IP:端口>

无线连接设备

adb connect 192.168.1.100:5555

adb disconnect <IP:端口>

断开无线连接

adb disconnect 192.168.1.100:5555

adb usb

切换到 USB 连接模式

-

adb tcpip <端口>

切换到无线调试模式

adb tcpip 5555

无线连接步骤

1.先用 USB 连接设备,设置端口:adb tcpip 5555

2.断开 USB,通过 IP 连接:adb connect 设备IP:5555(设备 IP 在 WLAN 设置中查看)

3.验证连接:adb devices

注意:设备与电脑需在同一局域网,部分设备需开启 "无线调试" 选项(Android 11+)

三、应用操作指令

应用安装与卸载

指令

功能

示例

adb install <APK路径>

安装应用

adb install app-debug.apk

adb install -r <APK路径>

覆盖安装(保留数据)

adb install -r update.apk

adb install -s <APK路径>

安装到 SD 卡

adb install -s large_app.apk

adb uninstall <包名>

卸载应用

adb uninstall com.example.myapp

adb uninstall -k <包名>

卸载但保留数据

adb uninstall -k com.example.myapp

常用参数

  • -r:保留数据和缓存文件,用于应用更新
  • -t:允许安装测试包
  • -d:允许降级安装(低版本覆盖高版本)

实战示例

# 覆盖安装并保留数据
adb install -r app-release.apk# 卸载应用但保留用户数据
adb uninstall -k com.example.myapp

应用运行控制

指令

功能

示例

adb shell am start -n <包名/Activity名>

启动应用组件

adb shell am start -n com.example.myapp/.MainActivity

adb shell am force-stop <包名>

强制停止应用

adb shell am force-stop com.example.myapp

adb shell am kill <包名>

杀死应用进程(系统可能重启)

adb shell am kill com.example.myapp

adb shell pm clear <包名>

清除应用数据和缓存

adb shell pm clear com.example.myapp

adb shell dumpsys package <包名>

查看应用详细信息

adb shell dumpsys package com.example.myapp

启动指定 Activity 示例

# 启动应用主Activity
adb shell am start -n com.example.myapp/.MainActivity# 启动带参数的Activity
adb shell am start -n com.example.myapp/.DetailActivity -e "id" "123" -e "name" "test"

查看应用安装路径

adb shell pm path com.example.myapp

四、文件传输指令

电脑与设备间传输文件

指令

功能

示例

adb push <本地路径> <设备路径>

从电脑发送文件到设备

adb push ./test.txt /sdcard/

adb pull <设备路径> <本地路径>

从设备拉取文件到电脑

adb pull /sdcard/logs ./local_logs

路径说明

  • 设备常用路径:/sdcard/(外部存储根目录)、/data/data/<包名>/(应用私有目录)
  • 注意权限:访问/data/data/下的文件可能需要 root 权限

实战示例

# 推送本地图片到设备相册
adb push ./photo.jpg /sdcard/DCIM/Camera/# 拉取应用缓存文件到本地
adb pull /data/data/com.example.myapp/cache/ ./app_cache

设备内部文件操作

结合adb shell可执行设备内部的文件操作:

# 进入设备shell环境
adb shell# 查看目录内容
ls /sdcard/# 创建目录
mkdir /sdcard/testdir# 移动文件
mv /sdcard/file1.txt /sdcard/testdir/# 复制文件
cp /sdcard/file1.txt /sdcard/testdir/file2.txt# 删除文件
rm /sdcard/test.txt# 查看文件内容
cat /sdcard/log.txt# 退出shell
exit

注意:部分目录操作需要 root 权限,可通过adb root获取(仅适用于已 root 设备或模拟器)

五、调试与诊断指令

日志查看

指令

功能

示例

adb logcat

查看系统日志

-

adb logcat -s <标签>

过滤指定标签的日志

adb logcat -s MyAppTag

adb logcat <包名>:<级别> *:S

过滤指定应用的日志

adb logcat com.example.myapp:V *:S

adb logcat > log.txt

将日志保存到文件

-

adb logcat -c

清除日志缓存

-

日志级别(从低到高):

  • V(Verbose):详细信息(默认)
  • D(Debug):调试信息
  • I(Info):普通信息
  • W(Warn):警告信息
  • E(Error):错误信息
  • F(Fatal):致命错误
  • S(Silent):无输出

实战示例

# 只显示应用的错误日志
adb logcat com.example.myapp:E *:S# 显示所有错误级别以上的日志并保存
adb logcat *:E > error_log.txt

进程与性能监控

指令

功能

示例

adb shell ps

查看设备进程列表

`adb shell ps

adb shell top

实时查看进程 CPU 占用

adb shell top -m 10(显示前 10 个进程)

adb shell dumpsys cpuinfo

查看 CPU 使用情况

`adb shell dumpsys cpuinfo

adb shell dumpsys meminfo <包名>

查看应用内存使用

adb shell dumpsys meminfo com.example.myapp

adb shell dumpsys gfxinfo <包名>

查看应用渲染性能

adb shell dumpsys gfxinfo com.example.myapp

实用技巧

  • adb shell top -d 3:每 3 秒刷新一次进程信息
  • adb shell dumpsys meminfo:不加包名可查看系统整体内存使用
  • adb shell dumpsys gfxinfo <包名> reset:重置渲染性能统计

屏幕与截图

指令

功能

示例

adb shell screencap <路径>

截取屏幕并保存到设备

adb shell screencap /sdcard/screenshot.png

adb exec-out screencap -p > screenshot.png

直接截取屏幕到电脑

-

adb shell screenrecord <路径>

录制屏幕视频

adb shell screenrecord /sdcard/demo.mp4

adb pull /sdcard/demo.mp4

将录制的视频拉取到电脑

-

屏幕录制参数

  • --time-limit 30:限制录制时长(默认 180 秒)
  • --bit-rate 4M:设置比特率(默认 4Mbps)
  • --size 1280x720:设置录制分辨率

示例

# 录制60秒,比特率8Mbps的视频
adb shell screenrecord --time-limit 60 --bit-rate 8M /sdcard/gameplay.mp4# 直接截图到电脑
adb exec-out screencap -p > current_screen.png

六、系统与高级指令

系统信息与控制

指令

功能

示例

adb shell getprop

查看所有系统属性

`adb shell getprop

adb shell setprop <属性名> <值>

设置系统属性(需 root)

-

adb shell getevent

查看输入事件(如按键、触摸)

-

adb shell input <命令>

模拟输入事件

adb shell input tap 500 1000(点击屏幕坐标)

adb shell dumpsys

查看系统服务状态

adb shell dumpsys battery(电池状态)

adb shell date <时间>

设置系统时间(需 root)

adb shell date 20231231.235959

模拟输入示例

# 点击屏幕坐标(500, 1000)
adb shell input tap 500 1000# 滑动屏幕(从(100,500)到(900,500))
adb shell input swipe 100 500 900 500 500(持续500ms)# 输入文本
adb shell input text "HelloADB"# 按电源键
adb shell input keyevent KEYCODE_POWER# 按返回键
adb shell input keyevent KEYCODE_BACK

权限与 root 相关

指令

功能

适用场景

adb root

以 root 权限重启 ADB

已 root 设备获取高级权限

adb unroot

退出 root 权限

恢复普通用户模式

adb shell su -c <命令>

以 root 权限执行命令

adb shell su -c rm /system/app/XXX

adb shell pm grant <包名> <权限>

授予应用权限

adb shell pm grant com.example.myapp android.permission.WRITE_SECURE_SETTINGS

adb shell pm revoke <包名> <权限>

撤销应用权限

adb shell pm revoke com.example.myapp android.permission.CAMERA

注意

  • 大部分设备需要解锁 Bootloader 才能获取 root 权限
  • pm grant只能授予应用在 Manifest 中声明的权限
  • 特殊权限(如WRITE_SECURE_SETTINGS)需通过 ADB 或 root 授予

七、实用技巧与常见问题

提高效率的技巧

1.别名设置:为常用指令设置别名(如在.bashrc 中):

alias adbip='adb connect 192.168.1.100:5555'
alias adbl='adb logcat -s MyApp'
alias adbs='adb shell'

2.多设备操作:当连接多个设备时,用-s指定设备:

adb -s 192.168.1.100:5555 install app.apk
adb -s emulator-5554 shell

3.命令组合:结合管道符实现复杂功能:

# 查找应用进程并杀死
adb shell ps | grep com.example.myapp | awk '{print $2}' | xargs adb shell kill

4.ADB 路径自动补全:配置 bash 自动补全脚本,支持指令和路径补全

常见问题解决

1.设备连接失败(offline 状态)

  • 解决方案:重启 ADB 服务器(adb kill-server && adb start-server)
  • 重新插拔 USB 线或重启设备

2.无权限访问设备(no permissions)

  • Windows:在设备上授权 USB 调试
  • Linux/macOS:执行sudo chmod 777 /dev/bus/usb/<设备路径>(路径可通过lsusb查看)

3.应用安装失败(INSTALL_FAILED_XXX)

  • INSTALL_FAILED_INSUFFICIENT_STORAGE:设备存储空间不足
  • INSTALL_FAILED_VERIFICATION_FAILURE:关闭 "验证应用" 选项
  • INSTALL_FAILED_UPDATE_INCOMPATIBLE:先卸载旧版本再安装

4.无线连接超时

  • 确保设备与电脑在同一网络
  • 检查防火墙设置,允许 5555 端口通信
  • 尝试重启设备的网络或 ADB 服务

八、总结

ADB 是 Android 开发的瑞士军刀,掌握这些指令能显著提升日常开发和调试效率。本文涵盖了设备管理、应用操作、文件传输、调试诊断等核心场景的常用指令,建议初学者从基础指令开始练习,逐步掌握高级用法。

实际使用中,不必死记硬背所有指令,可将本文作为速查表随时查阅。随着使用频率增加,自然会熟练掌握常用命令。ADB 的强大之处在于其灵活性,通过组合不同指令,能解决几乎所有设备交互问题,是每个 Android 开发者必备的技能。

http://www.dtcms.com/a/331518.html

相关文章:

  • ADB服务端调试
  • markdown格式中table表格不生效,没有编译的原因
  • Mybatis Plus 分页插件报错`GOLDILOCKS`
  • 视频号主页的企业信息如何设置?
  • 深入了解linux系统—— 线程概念
  • Fiddler抓包
  • nginx --ssl证书生成mkcert
  • PCB爆板产生的原因有哪些?如何预防?
  • 第三十一天(系统io)
  • Qwen2-VL-2B 轻量化部署实战:数据集构建、LoRA微调、GPTQ量化与vLLM加速
  • 归并排序专栏
  • 机器学习基础讲解
  • Java -- HashSet的全面说明-Map接口的常用方法-遍历方法
  • feed-forward系列工作集合与跟进(vggt以后)
  • 第二十三天:求逆序对
  • Day54 Java面向对象08 继承
  • 附:日期类Date的实现
  • Pytorch在FSDP模型中使用EMA
  • Leetcode_1780.判断一个数字是否可以表示成三的幂的和
  • UE5 C++ 删除文件
  • BotCash:GPT-5发布观察 工程优化的进步,还是技术突破的瓶颈?
  • Spring Boot + Redis Cluster 测试
  • 回流(Reflow)与重绘(Repaint):浏览器渲染性能优化核心
  • 演员念真主演《镇恶追凶》辽宁杀青
  • 数字电路上的通讯速度是越快越好还是越慢越好?
  • 【二分图】染色问题
  • 企业智脑UMI AIGC SaaS:解锁AI时代全场景生产力,中小微企业转型利器
  • Linux学习-多任务(进程)
  • **隐私沙盒:发散创新之光**随着互联网技术的飞速发展,数据安全和隐私保护逐渐成为人们关注的焦点。隐私沙盒作为一种新兴
  • Ping32 与绿盾再对比:Ping32 以创新与适配领跑数据安全​