常用的adb命令

常用的adb命令,第1张

在平时的工作中,会经常用到adb命令,在这里稍微整理了一下。 一.概要 1.什么是adb? adb全称为Android Debug Bridge,就是起到调试桥的作用。顾名思义,adb就是一个debug工具。 2.adb工作原理 不是很理解?那就来看看它的工作原理吧。上图是一个简单的adb工作原理图。adb客户端服务器端程序,由上图可以看出它主要三个组件组成:Client,Server,Daemon。 (1)当你启动一个adb Client(客户端),Client首先会选确认是否已有一个adb Server(服务器)进程在运行,如果没有,则会启动Server进程。此时,adb Server就会绑定本地的TCP端口5037,并监听adb Client发来的命令。 (2)接着,Server将会扫描所有5555到5585范围内的奇数端口来定位所有的模拟器设备,并与之建立连接。一旦Server找到 了adb daemon(守护程序),它将建立一个到该端口的连接,这样,我们就可以使用adb命令控制和访问模拟器或设备了。在这里,需注意的是任何模拟器或设备实例会取得两个连续的端口:一个偶数端口用来相应控制台的连接,和一个奇数端口用来响应adb连接。 3.adb的作用 借助adb工具,我们可以管理设备或手机模拟器的状态,还可以进行很多手机 *** 作,如安装软件、系统升级、运行shell命令等等。简而言之,adb就是连接Android手机和PC端的桥梁,可以让用户在电脑上对手机进行全面的 *** 作。 二.常用命令 这个部分主要介绍adb的使用方法和一些常用的命令。 设置adb环境:将android sdk工作目录添加到系统环境变量中,则可使用adb命令了。 1. adb devices 查看当前连接的设备(连接计算机的Android设备或者模拟器)。2.adb install adb install <apk文件路径>,将指定的apk安装到设备上,安装的apk包会放在/data/app目录下。 几个参数: -r 强制安装 -d(真机,多个设备中只有一个真机时适用) -e(模拟器,多个设备中只有一个模拟器时适用) -s(指定设备,后接序列号) adb –s 44a188f9 install –r test.apk(其中44a188f9即序列号,通过adb devices可获取)3.adb uninstall adb uninstall <apk包名> adb uninstall –k <apk包名> -k参数为卸载软件时保留配置和缓存文件4.adb reboot 重启android设备5.adb shell 通过adb shell 命令,就可以进入设备或者模拟器的shell环境了,在这个Linux shell中,我们就可以执行各种Linux命令了。 如果只想执行一条shell命令,就可以采用:adb shell [shell_command] 在实际使用中,经常与grep或findstr一起使用,起到过滤作用,查看自己需要的关键信息。6.adb shell su 前提手机已经root。获取adb shell的root权限。 使用su提权,用户命令提示符有$变成#,如果手机没有root,会提示su:permission denied。7.adb shell ps/top 查看当前终端中的进程信息,如pid等。8.adb shell am/pm am全称为activity manager,可使用am命令模拟各种系统的行为,如去启动一个activity,强制停止进程,发送广播进程,修改设备屏幕属性等。 如:adb shell am start <apk包名>/<activityName>:启动一个activity。 pm全称为package manager,利用pm命令可模拟android行为或查询设备上的应用等。 如:adb shell pm list packages 列出当前设备所有已安装的程序的包名。说明: 管道符“|”:可以把标准的输入流与标准的输出流进行合并,或者把某个命令的标准输出流作为另一个命令的标准输入流。 exit退出shell。 由于grep为linux命令,运行单条adb shell 时并没有进入linux shell环境,并不能用grep等其他linux命令,只能用window cmd的命令。在这里可以用findstr来代替grep,使用方法为 findstr/grep [keyword] 更详细的内容可查看 参考文献3 和 参考文献4 。 对于常用的linux命令和常用的windows 控制台命令,以后再作总结。9.adb pull 和 adb push adb pull <设备中的文件路径><本地路径>:从模拟器或设备中复制文件到本地。 adb push <本地文件路径><设备中的路径>:将本地文件或目录复制到模拟器或设备。 这里还涉及到一个权限的问题,在后续的博文中再作介绍。10.adb shell dumpsys Android提供的dumpsys工具用于查看感兴趣的系统服务信息与状态。 参考下表:11.adb shell monkey 跑monkey是android自动化测试的一种手段,所谓monkey测试就是模拟用户的按键输入,触摸屏输入,手势输入等。当Monkey程序在模拟器或设备运行的时候,如果用户比如点击,触摸,手势或一些系统级别的事件的时候,它就会产生随机脉冲,所以可以用Monkey的随机重复的方法对apk作压力测试,来测试androidapp的稳定性。 如下为测试腾讯新闻apk的一个简单实例:说明:第一个-s指定设备,如果只连接了一台设备,可不用该参数。 -p <apk包名>只允许系统启动指定的app,如果不指定,将允许系统启动设备中的所有app,也可指定多个包。 --throttle <毫秒数>指定用户 *** 作(事件)间的时延。 --ignore-crashes 指定当应用程序崩溃时,Monkey依然发送事件,直到事件计数完成。 --ignore-timeouts 当应用程序发生ANR错误时,Monkey依然会发送事件,直到事件计数完成。 第2个-s,用于指定伪随机数生成器的seed值,如果seed相同,则两次Monkey测试所产生的事件序列也相同的。 -v 用于指定反馈信息级别,总共分为level 0、level 1、level 2三个级别,级别越高,输出的日志越详细。 最后的数字(这里是500):表示Monkey程序模拟500次随机用户 *** 作事件。 >输出测试结果到D:\monkeylog.txt 更详细的参数可查看 参考文献5 。 部分测试结果如下:对于测试结果的分析,通过搜索关键词来定位错误,主要包括以下四个方面: 1)ANR(Application Not Response):程序无响应,一般主线程超过5秒没处理就会出现ANR错误。通过搜索ANR关键词来定位关键的事件信息。除了导出日志外,还可以将/data/anr/目录下的trace.txt文件导出,用来定位分析问题。使用>adbpull /data/anr/trace.txt d:\ 将trace.txt文件导出到d盘。 2)ForceClosed或其他异常退出信息:通过搜索Fatal关键词来定位。 3)崩溃问题:通过搜索Exception关键词来定位。 4)发生异常后,通过搜索Crash关键词来定位到详细的堆栈信息。 12.kill kill用来中止一个进程。 比如我们在跑monkey的时候,怎么强制关闭monkey呢,可以用kill <monkey进程PID> 说明:另开启一个cmd,找到monkey的pid号,然后杀掉即可。 参考文献: 1.Android调试桥: http://www.iteye.com/topic/2600422.Android性能分析工具dumpsys的使用: http://www.open-open.com/lib/view/open1405061994872.html3.adb shell 中的am pm命令: http://www.android100.org/html/201312/09/4957.html4.adb shell 启动应用程序的方法: http://blog.chinaunix.net/uid-26997997-id-3350449.html5.Monkey压力测试详解: http://blog.csdn.net/huangbiao86/article/details/8490743

Android Debug Bridge,一般简称为adb,主要存放在sdk安装目录下的platform-tools文件夹中,它是一个非常强大的命令行工具,通过这个工具你能够与你的android设备进行交互。同时这是一个包含了以下三部分的cs模式的程序:

1) adb client

从图中,我们知道client是运行在PC端的,每当我们发起一个adb命令的时候,就会开启一个client程序。当然,当我们开启DDMS或者ADT的时候,也会自动创建client。

当我们开启一个client的时候,它首先会去检测后台是否已经有一个server程序在运行着,否则会开启一个adb-server进程。

所有的client都是通过5037端口与adb-server进行通信的。

2)adb daemon(adbd)

从图中,我们知道daemon是作为一个后台进程运行在模拟器/真实Android设备中的。

daemon使用端口的范围是5554-5585,每个模拟器/设备连接到PC端时,总会开启这么一个后台进程,并且为其分配了两个连续的端口,比如:

Emulator 1, console: 5554

Emulator 1, adb: 5555

也正因为每个设备都分一组两个端口,也已adb连接手机的最大数量为16。

说回端口的作用,在这两个端口中,其中偶数端口是用于server 与设备进行交互的,可以让server直接从设备中读取数据,而奇数端口是用来与设备的adbd进行连接通信的。

2) adb server

从图中,我们同样可以知道,server也是作为一个后台的程序运行在PC端的,他负责管理client进程以及adb daemon之间的通信。

当一个server开启的时候,他会自动绑定并且监听5037端口,接收client通过该端口发送过来的命令。同时server还会对5555-5585间的奇数端口进行扫描,进行对已连接设备的定位。

1.2 常用的adb命令

首先我们先来介绍一下,adb命令的使用格式吧:

adb [-d|-e|-s ]

adb是必须的,接下来方括号[]里面的内容不是必须的,最后才是我们需要执行的命令 *** 作,例如 adb -s emulator-5554 install UCBrowser.apk (这是安装UC浏览器的意思)

下面先介绍下,前面几个参数的含义吧:

-d: 让唯一连接到该PC端的真实安卓设备执行命令,如果发现USB中连接有多部设备,将会报错

-e: 让唯一连接到该PC端的模拟器执行命令,如果发现开启了多个模拟器,将会报错

-s:通过设备的序列号进行指定设备执行命令

如果设备只连接有一个设备或者一个模拟器的时候,可以不用声明这三个参数,adb默认会让这部唯一连接到的设备进行命令执行。

ok,下面开始讲解常用的命令吧:

1) 查看当前PC端连接有多少设备:

adb devices

终端中的执行结果为:

从上图中,我们看到了设备有的两种状态,其实执行该命令,可能返回的状态有三种:

I. device 设备已经成功连接到了adb-server

  II. offline 设备并没有连接到adb或者没有响应

  III. no device 并没有设备/模拟器连接

2) 查看adb的版本

adb version

终端中的执行结果为:

3) 给设备进行软件的安装

adb -s install

eg:

adb -s 99eb07a9 install D://Test.apk

终端中的执行结果为:

除了上面这种方法,我们还有另外一个命令:

adb -s shell pm install [options]

其中[options]中最常用的选项是-r,代表着本次安装是重新安装,会保留用户数据。

4) 卸载设备中已经安装的软件

adb -s uninstall

eg:

adb -s 99eb07a9 uninstall cn.uc.test

终端中的执行结果为:

除了上面这种方法,我们还有另外一个命令:

adb -s uninstall [options]

这里的options是-k,加上该参数表明卸载软件后依旧保留用户数据

5) 将数据从设备复制到PC中

adb -s pull

eg:

adb -s 99eb07a9 pull /sdcard/stericson-ls D://

终端的执行结果:

在D://盘中我们也可以发现stericson-ls文件

6) 讲数据从PC端复制到设备中

adb -s push

eg:

adb -s 99eb07a9 push d://stericson-ls /sdcard/

终端的执行结果:

7) 获取连接到的手机的序列号

adb get-serialno

终端的执行结果:

8)获取设备的连接状态

adb -s get-state

eg:

adb -s 99eb07a9 get-stat

终端的执行结果:

9) 等待设备连接成功

adb wait-for-device

该命令将会阻塞一直到默认连接的那部机器状态变为device,也就是连接成功。

10) adb-server 的开启与关闭

adb kill-server

adb start-server

终端的执行结果:

有时候我们开启server会失败,这是因为我们装了的手机助手,豌豆荚或者其他软件自带有自己的adb,导致端口冲突开启失败。主要关掉那些软件并且杀掉那些软件自带的adb进程重来即可。

1.2 手机执行Shell命令

众所周知,Android的内核本身就是Linux,所以Android本身也支持Linux命令,但是因为是手机系统,所以进行了一定的删减,部分命令不支持,而不支持的部分,我们可以通过安装busybox这个软件进行

填补。

下面我们讲解下如何在手机中执行Shell命令:

1) 每次都加上adb shell来进行命令的发送与执行

adb shell

2) 先通过adb shell进入手机Shell执行状态,然后直接输入Linux命令,如图:

1.3 Activity Manager 常用命令与参数说明

一般情况下,我们最常用它来进行app的开启,并且传递一定的参数过去,比如:

adb shell am start -a android.intent.action.VIEW -n cn.uc.test/.MainActivity -d

在这里就不做太过详细和重复的说明了

1.4 Package Manager 常用命令与参数说明

1) 使一个apk处于禁用状态,相当于卸载了:

disable

其中 PACKAGE_OR_COMPONENT的格式是 package/class, 如 com.UCMobile/.main.UCMobile

eg:

adb shell su disable com.UCMobile/.main.UCMobile

终端执行结果:

同时我们在手机上发现,UC浏览器的图标不见了

2) 让一个apk从禁用状态恢复过来

enable

其中 PACKAGE_OR_COMPONENT的格式是 package/class, 如 com.UCMobile/.main.UCMobile

eg:

adb shell su enable com.UCMobile/.main.UCMobile

终端执行结果:

同时我们从手机上发现,UC浏览器的图标又回来啦。

3) 查看一个apk所在的路径

pm path

eg:

adb shell pm path com.UCMobile

终端执行结果:

4) 查看手机中装的所有的包

pm list packages

再次不做过多的说明

1.5其他常用的adb命令

1) 屏幕录像

例如,屏幕开始录像并且储存到/sdcard中,同时名字为demo.mp4

adb shell screenrecord /sdcard/demo.mp4

2) 关闭设备请求,开启设备

adb shell stop

adb shell start

3)设备关机以及重启

adb reboot

adb shutdown


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/7347491.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-04
下一篇 2023-04-04

发表评论

登录后才能评论

评论列表(0条)

保存