该系列文章总纲链接:专题分纲目录 Android系统基础
adb shell 后面跟的命令主要来自:源码\system\core\toolbox目录 和 源码\frameworks\base\cmds目录。
1 adb命令
@1 常用命令
- adb get-product //获取设备ID
- adb get-serialno //获取设备序列号
- adb devices //查看当前连接的设备, 连接到计算机的android设备或者模拟器将会列出显示,示例效果如下:
- List of devices attached
- emulator-5554 device //表示是模拟器
- HT95LKF00945 device //表示是手机
- adb wait-for-device //等待设备连接,连接后执行adb devices
- adb shell [command] //可以执行各种Linux的命令,即执行一条shell命令[command]
- adb shell //以user用户身份进入到终端设备
- adb root //以root方式进入终端设备
- adb reboot //重启进入到Android
- adb reboot bootloader //重启进入到bootloader
- adb reboot recovery //重启进入到recovery模式
- adb remount //重新挂载系统分区,就是将系统分区重新挂载为可写
- adb start-server //开启adb相关服务
- adb kill-server //如果adb相关服务开启,则杀掉该服务进程
- adb remount //重新挂载system分区,使其可读可写;主要用于操作系统目录时提前进行的操作
- adb help //查看帮助信息
- adb version //查看adb当前使用版本
- adb -s [device number] //使用adb连接指定设备号(device number)的设备,同时连接多个手机时会用到,通常与其他命令叠加使用
- adb get-state //查看模拟器/设施的当前状态,打印出的结果一般是offline|bootloader|device
@2 adb网络调试步骤
连接USB数据线,执行以下命令:
adb shell ifconfig #查看android设备ip地址
adb tcpip 5555 # (设置端口号)
断开USB数据线,执行以下命令:
adb connect ip地址:5555
如果失败则执行 adb kill-server,再次连接即可。
@3 adb 输入中文步骤
到github网站上下载 ADBKeyboard.apk,源码和应用文件 路径为:https://github.com/senzhk/ADBKeyBoard
下载后进入 settings,找到语言和输入,各个安卓版本略有不同,然后选择键盘:ADB keyboard 并设置为默认。
执行命令即可:
adb shell am broadcast -a ADB_INPUT_TEXT --es msg '中文输入'
2 查看log相关
@1 adb logcat
-b 选项 //Android日志系统为日志消息保持了多个循环缓冲区,要想查看这些附加的缓冲区,可使用该选项,以下是可以指定的缓冲区
- radio //查看包含在无线/电话相关的缓冲区消息
- events //查看事件相关的消息
- main //查看主缓冲区 (默认缓冲区)
-v 选项 //控制日志格式,日志消息在标记和优先级之外还有很多元数据字段,这些字段可以通过修改输出格式来控制输出结果,
- brief //显示优先级/标记和原始进程的PID (默认格式)
- process //仅显示进程PID
- tag //仅显示优先级/标记
- thread //仅显示进程:线程和优先级/标记
- raw //显示原始的日志信息,没有其他的元数据字段
- time //显示日期,调用时间,优先级/标记,PID
- long //显示所有的元数据字段并且用空行分隔消息内容
-c 选项
- 清除之前的log
@2 日志过滤输出相关说明:
每一条日志消息都有一个标记tag和优先级Priority与其关联。标记是一个简短的字符串,用于标识原始消息的来源 (例如"View" 来源于显示系统)。优先级是下面的字符,顺序是从低到高:
- V明细(最低优先级)|
- D调试信息|
- W警告|
- E错误|
- F严重错误|
- S无记载(最高优先级,没有什么会被记载)|
通过运行logcat ,可以获得一个系统中使用的标记和优先级的列表,观察列表的前两列,给出的格式是<priority>/<tag>。这里是一个日志输出的消息,优先级是I,标记是ActivityManager,如下所示:
I/ActivityManager( 585): Starting activity: Intent { action=android.intent.action...}
如果想要减少输出的内容,可以加上过滤器表达式进行限制,过滤器可以限制系统只输出感兴趣的标记-优先级组合。过滤器表达式的格式是tag:priority...,其中tag是标记,priority是最小的优先级,该标记标识的所有大于等于指定优先级的消息被写入日志。也可以在一个过滤器表达式中提供多个这样的过滤,它们之间用空格隔开。
@3 使用logcat来过滤日志的输出
示例1:仅输出标记为"ActivityManager"并且优先级大于等于"Info"和标记为"MyApp"并且优先级大于等于"Debug"的日志
$adb logcat ActivityManager:I MyApp:D *:S
上述表达式最后的 *:S 用于设置所有标记的日志优先级为S,这样可以确保仅有标记为ActivityManager和“MyApp”的日志被输出,使用 *:S 是可以确保输出符合指定的过滤器设置的一种推荐的方式,这样过滤器就成为了日志输出的“白名单”。
示例2:显示所有优先级大于等于"warning"的日志:
$adb logcat *:W
示例3:如果在开发用电脑上运行 logcat (相对于运行运程shell而言),也可以通过ANDROID_LOG_TAGS环境变量设置默认的过滤器表达式:
$export ANDROID_LOG_TAGS="ActivityManager:I MyApp:D *:S"
注意:如果是在远程shell或是使用adb shell logcat 命令运行logcat,ANDROID_LOG_TAGS 不会导出到模拟器或手机设备上
3 文件传输相关
$adb push <本地路径> <远程路径> //用push命令可以把本机电脑上的文件或者文件夹复制到设备(手机)
$adb pull <远程路径> <本地路径> //用pull命令可以把设备(手机)上的文件或者文件夹复制到本机电脑
注意:对于root版本可直接执行文件操作,对于user-debug版本,在文件传输之前要执行
$adb root
$adb remount
4 权限控制相关(Android5.0以后很常见)
在在root的ADB下(提示符为#时)或者终端模拟器里有效
$adb setenforce [N] //设置当前的工作模式N为0,表示permissive模式;为1表示enforcing模式
$adb getenforce //获取当前的工作模式两个值[permissive,enforcing]