Android系统基础(05) Android系统源码 调试

该系列文章总纲链接:专题分纲目录 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" 来源于显示系统)。优先级是下面的字符,顺序是从低到高:

  1. V明细(最低优先级)|
  2. D调试信息|
  3. W警告|
  4. E错误|
  5. F严重错误|
  6. 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]

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

图王大胜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值