为什么安卓设备用pm install -rlinux常用命令全集静默安装应用时报错Failure [INSTALL_FAILED_INVALID_APK]?

求教Android 将APK安装到/system/app的方法
[问题点数:40分,结帖人sfer520_1314]
本版专家分:0
结帖率 90.91%
CSDN今日推荐
本版专家分:0
本版专家分:0
本版专家分:1697
本版专家分:0
本版专家分:0
本版专家分:10
本版专家分:0
本版专家分:0
本版专家分:0
本版专家分:18869
本版专家分:0
本版专家分:0
本版专家分:143
本版专家分:0
本版专家分:0
本版专家分:371
本版专家分:6794
2013年7月 移动平台大版内专家分月排行榜第三
本版专家分:371
本版专家分:30
本版专家分:0
本版专家分:0
本版专家分:0
本版专家分:1009
本版专家分:0
本版专家分:0
本版专家分:0
匿名用户不能发表回复!
其他相关推荐
第一种:不需要少些系统镜像(system.img),只需要root系统。
具体操作:
1、 将手机连接电脑,并开启USB调试模式。
2、 通过CMD进入Windows命令行窗口,输如:adbshell如下图所示:
3、 如果是root就可以进入下一步,不是root需要root自己的手机,并授权控制台root权限。
4、执行exit退出adb shell,执行adbremoun
参考 http://blog.csdn.net/sergeycao/article/details/8198205
一、如何将带源码的APK预置进系统?
在 packages/apps 下面以需要预置的 APK的 名字创建一个新文件夹,以预制一个名为Test的APK 为例
将 Test APK的Source code 拷贝到 Test 文件夹下,删除 /b
adb remount
adb shell mkdir -p /system/priv-app/stu/lib/arm/
adb push D:\armeabi\. /system/priv-app/stu/lib/arm/
adb push E:\works\projects\MDMSTU\app\MdmApp\build\outputs\apk\debug\.
转:http://blog.csdn.net/myarrow/article/details/8778621#comments
为了能把应用程序安装到SD卡和TF卡上,Android系统默认是不支持的,它只有一个asec mount点: /mnt/secure/asec,在我的系统中,此mount点由/mnt/sdcard给占用了,所以TF卡就支持不了。为了解决此问
Android.mk文件
LOCAL_MODULE := test
LOCAL_MODULE_TAGS := optional
LOCAL_SRC_FILES := $(LOCAL_MODULE).apk
LOCAL_MODULE_CLASS := APPS
LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)
android:installLocation简析
在Froyo(android 2.2,API Level:8)中引入了android:installLocation.通过设置该属性可以使得开发者以及用户决定程序的安装位置.
android:installLocation隶属于AndroidManifest.XML中的manifest节点.如下所示:
xmlns:andro
Android安装系统App,通过命令行 adb push到/system/app下。
如果手机在安装了几款应用后发现的确存储空间不够,由此想到如果能够将应用安装到SD卡里面就好了,其实如果你的应用不能转移到SD卡上的话,被卸载的几率又大了点。Android系统在2.1版本之前,应用程序是只能安装到机身内存(RAM)中,这一特性从某种角度上讲,阻止了Android的发展,因为RAM的空间是有限的,所以这一特性限制了应用程序的体积,也就限制了应用程序的功能。
自从Android
简单介绍一下如何将Android App安装成系统应用:
1、首先你要确保你手中的机器已经root过
2、将APK copy到sd卡根目录下
3、进入终端
4、切换超级用户
mount -o remount /system
6、将APK copy到系统目录下
busybox mv /storage/sdcard0/xxx.apk /sy
APK为AndroidPackage的缩写
应用安装涉及到如下几个目录:
system/app------系统自带的应用程序
data/app -------用户程序安装的目录,安装时把apk文件复制到此目录
data/data ------存放应用程序的数据
data/dalvik-cache-----将apk中的dex文件安装到dalvik-cache目录下Android测试常用adb命令大全Android测试常用adb命令大全冰晶蜂皇百家号针对移动端Android的测试(更多相关精彩内容请戳:干货!手机APP进行测试的流程详解),adb命令是很重要的一个点,必须将常用的 adb命令熟记于心,将会为 Android测试带来很大的方便,其中很多命令将会用于自动化测试的脚本当中。Android Debug Bridgeadb其实就是 Android Debug Bridge, Android调试桥的缩写,adb是一个 C/S架构的命令行工具,主要由 3部分组成:运行在 PC端的 Client :可以通过它对 Android应用进行安装、卸载及调试Eclipse中的 ADT、SDK Tools目录下的 DDMS、Monitor等工具,都是同样地用到了 adb的功能来与 Android设备进行交互。PC端的手机助手,诸如 360手机助手、豌豆荚、应用宝等,其除了安装第三方应用方便,其他的功能,基本上都可以通过 adb命令去完成,这里建议测试人员尽量不要在电脑上安装这类手机助手,因为其自带的 adb程序可能会与 Android SDK下的 adb程序产生冲突,5037端口被占用,导致使用 adb命令时无法连接到设备运行在 PC端的 Service :其管理客户端到 Android设备上 adb后台进程的连接adb服务启动后,Windows可以在任务管理器中找到 adb.exe这个进程运行在 Android设备上的 adb后台进程执行 adb shell ps |grepadbd ,可以找到该后台进程,windows请使用 findstr替代 grep[xuxu:~]$ adb shell ps | grep adbdroot 2 ffffffff 00019bb4 S /sbin/adbd这里注意一个地方,就是 adb使用的端口号,5037,有必要记一下接下来我将 adb命令分为三部分进行介绍,adb命令、adb shell命令、linux命令adb命令在开发或者测试的过程中,我们可以通过 adb来管理多台设备,其一般的格式为:adb [-e | -d | -s ]在配好环境变量的前提下,在命令窗口当中输入 adb help或者直接输入 adb ,将会列出所有的选项说明及子命令。这里介绍一些里面常用的命令:adb devices ,获取设备列表及设备状态[xuxu:~]$ adb devicesListof devices attached44c826a0 deviceadb get-state ,获取设备的状态[xuxu:~]$ adb get-statedevice设备的状态有 3钟,device , offline , unknowndevice:设备正常连接offline:连接出现异常,设备无响应unknown:没有连接设备adb kill-server , adb start-server ,结束 adb服务,启动 adb服务,通常两个命令一起用一般在连接出现异常,使用 adb devices未正常列出设备,设备状态异常时使用 kill-server,然后运行 start-server进行重启服务adb logcat ,打印 Android的系统日志,这个可以单独拿出来讲adb bugreport ,打印dumpsys、dumpstate、logcat的输出,也是用于分析错误输出比较多,建议重定向到一个文件中adb bugreport & d:\bugreport.logadb install ,安装应用,覆盖安装是使用 -r选项windows下如果需要安装含有中文名的 apk ,需要对 adb进行修改,百度可以找到做出修改的adb ,支持中文命令的 apk,请自行搜索adbuninstall,卸载应用,后面跟的参数是应用的包名,请区别于 apk文件名'-k' means keep the data and cache directories , -k选项,卸载时保存数据和缓存目录adb pull ,将 Android设备上的文件或者文件夹复制到本地例如复制Sdcard下的 pull.txt文件到 D盘:adb pull sdcard/pull.txt d:\如果需要重命名为 rename.txt:adb pull sdcard/pull.txt d:\rename.txt注意权限,复制系统权限的目录下的文件,需要 root ,并且一般的 Android机 root之后并不能使用命令去复制,而需要在手机上使用类似于 RE的文件浏览器,先对系统的文件系统进行挂载为可读写后,才能在手机上复制移动系统文件,这里推荐使用小米手机的开发版本,IUNI也是不错滴~~adb push ,推送本地文件至 Android设备例如推送 D盘下的 push.txt至 Sdcard:adbpush d:\push.txt sdcard/sdcard后面的斜杠不能少,否则会出现下面的错误:[xuxu:~]$ adb push push.txt sdcardfailed tocopy'push.txt'to'sdcard': Is a directory权限问题同 pull命令adb root , adb remount,只针对类似小米开发版的手机有用,可以直接已这两个命令获取 root权限,并挂载系统文件系统为可读写状态adb reboot ,重启 Android设备bootloader ,重启设备,进入 fastboot模式,同 adb reboot-bootloader命令recovery ,重启设备,进入 recovery模式,经常刷机的同学比较熟悉这个模式adb forward ,将宿主机上的某个端口重定向到设备的某个端口adbforwardtcp:1314tcp:8888执行该命令后所有发往宿主机 1314端口的消息、数据都会转发到 Android设备的 8888端口上,因此可以通过远程的方式控制 Android设备。adb connect远程连接Android设备手机、PC处于相同的网络下,手机 root ,安装应用 adbWireless ,启动应用后点击界面中间的按钮:接着运行 adb connect 192.168.1.102 ,即可通过无线的方式连接手机,缺点是速度比较慢adb shell命令有人问过我,为什么会知道这么多的命令,答案就是我比较爱折腾,这里大家先要了解我为什么要区分 adb命令和 adb shell命令 。简单点讲,adb命令是 adb这个程序自带的一些命令,而 adb shell则是调用的 Android系统中的命令,这些 Android特有的命令都放在了 Android设备的 system/bin目录下,例如我再命令行中敲这样一个命令:[xuxu:~]$ adb shell hehe/system/bin/sh:hehe: not found很明显,在 bin目录下并不存在这个命令。自己爱折腾,想看看有哪些命令,也不想去找文档,于是就启动模拟器,将整个 system/bin目录复制了出来,然后一个一个的去试。。囧~~打开这些文件就可以发现,里面有些命令其实是一个 shell脚本,例如打开monkey文件:# to start "monkey"on the device, which has a very rudimentary# shell.#base=/systemexport CLASSPATH=$base/framework/monkey.jartrap "" HUPexec app_process $base/bin com.android.commands.monkey.Monkey $*再比如打开 am:#!/system/bin/sh## to start "am"on the device, which hasa very rudimentary# shell.#base=/systemexport CLASSPATH=$base/framework/am.jarexec app_process $base/bincom.android.commands.am.Am "$@"还有 SDK sources/android-20/com/android/commands目录下:[xuxu:...oid-20/com/android/commands]$ pwd/Users/xuxu/utils/android/android-sdk-macosx/sources/android-20/com/android/commands[xuxu:...oid-20/com/android/commands]$ ll total 0drwxr-xr-x 3 xuxu staff 102B 4 2 10:57 amdrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 bmgrdrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 budrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 contentdrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 imedrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 inputdrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 mediadrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 pmdrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 requestsyncdrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 settingsdrwxr-xr-x 7 xuxu staff 238B 4 2 10:57 svcdrwxr-xr-x 6 xuxu staff 204B 4 2 10:57uiautomatordrwxr-xr-x 3 xuxu staff 102B 4 2 10:57 wm有没有熟悉的命令? am 、pm、uiautomator ...下面介绍一些常用的 adb shell命令 (其中pm、am命令比较庞大,使用四级标题)pmPackage Manager ,可以用获取到一些安装在 Android设备上得应用信息pm的源码 Pm.java ,直接运行 adb shell pm可以获取到该命令的帮助信息pm list package列出安装在设备上的应用不带任何选项:列出所有的应用的包名(不知道怎么找应用的包名的同学看这里)adb shell pm list package-s:列出系统应用adb shell pm list package -s-3:列出第三方应用adb shell pm list package -3-f:列出应用包名及对应的apk名及存放位置adb shell pm list package -f-i:列出应用包名及其安装来源,结果显示例子:package:com.zhihu.android installer=com.xiaomi.marketadb shell pm list package -i命令最后增加 FILTER:过滤关键字,可以很方便地查找自己想要的应用参数组合使用,例如,查找三方应用中知乎的包名、apk存放位置、安装来源:[xuxu:~]$ adb shell pm list package -f -3 -i zhihupackage:/data/app/com.zhihu.android-1.apk=com.zhihu.android installer=com.xiaomi.marketpm path列出对应包名的 .apk位置[xuxu:~]$ adb shell pm path com.tencent.mobileqqpackage:/data/app/com.tencent.mobileqq-1.apkpm list instrumentation ,列出含有单元测试 case的应用,后面可跟参数 -f (与 pm list package中一样),以及 [TARGET-PACKAGE]pm dump ,后跟包名,列出指定应用的 dump信息,里面有各种信息,自行查看adb shell pm dump com.tencent.mobileqqPackages:Package [com.tencent.mobileqq] ():userId=10091 gids=[, , 1015]pkg=Package{ com.tencent.mobileqq}codePath=/data/app/com.tencent.mobileqq-1.apkresourcePath=/data/app/com.tencent.mobileqq-1.apknativeLibraryPath=/data/app-lib/com.tencent.mobileqq-1versionCode=242 targetSdk=9versionName=5.6.0applicationInfo=ApplicationInfo{43842cc8 com.tencent.mobileqq}flags=[ HAS_CODE ALLOW_CLEAR_USER_DATA ]dataDir=/data/data/com.tencent.mobileqqsupportsScreens=[small, medium, large, xlarge, resizeable, anyDensity]usesOptionalLibraries:com.google.android.media.effectscom.motorola.hardware.frontcameratimeStamp=4:04:24firstInstallTime=0:50:07lastUpdateTime=4:05:02installerPackageName=com.xiaomi.marketsignatures=PackageSignatures{ []}permissionsFixed=true haveGids=true installStatus=1pkgFlags=[ HAS_CODE ALLOW_CLEAR_USER_DATA ]User 0: installed=true blocked=false stopped=false notLaunched=false enabled=0grantedPermissions:android.permission.CHANGE_WIFI_MULTICAST_STATEcom.tencent.qav.permission.broadcastcom.tencent.photos.permission.DATAcom.tencent.wifisdk.permission.disconnectpm install ,安装应用目标 apk存放于 PC端,请用 adb install安装目标 apk存放于 Android设备上,请用 pm install安装pm uninstall ,卸载应用,同 adbuninstall,后面跟的参数都是应用的包名pm clear ,清除应用数据pm set-install-location , pm get-install-location ,设置应用安装位置,获取应用安装位置[0/auto]:默认为自动[1/internal]:默认为安装在手机内部[2/external]:默认安装在外部存储am又是一个庞大的命令。。。am start ,启动一个 Activity,已启动系统相机应用为例启动相机[xuxu:~]$ adb shell am start -n com.android.camera/.CameraStarting: Intent { cmp=com.android.camera/.Camera }先停止目标应用,再启动[xuxu:~]$ adb shell am start -S com.android.camera/.CameraStopping: com.android.cameraStarting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.android.camera/.Camera }等待应用完成启动[xuxu:~]$ adb shell am start -W com.android.camera/.CameraStarting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.android.camera/.Camera }Status: okActivity: com.android.camera/.CameraThisTime: 500TotalTime: 500Complete启动默认浏览器打开一个网页[xuxu:~]$ adb shell am start -a android.intent.action.VIEW -d http://testerhome.comStarting: Intent { act=android.intent.action.VIEW dat=http://testerhome.com }启动拨号器拨打 10086[xuxu:~]$ adb shell am start -a android.intent.action.CALL -d tel:10086 Starting: Intent { act=android.intent.action.CALL dat=tel:xxxxx }am instrument ,启动一个 instrumentation ,单元测试或者 Robotium会用到am monitor ,监控 crash与 ANR[xuxu:~]$ adb shell am monitorMonitoring activity manager... available commands:(q)uit: finish monitoring** Activity starting: com.android.cameraam force-stop ,后跟包名,结束应用am startservice ,启动一个服务am broadcast ,发送一个广播还有很多的选项,自己多多发掘~~input这个命令可以向 Android设备发送按键事件,其源码 Input.javainput text ,发送文本内容,不能发送中文adb shell input text test123456前提先将键盘设置为英文键盘input keyevent ,发送按键事件,KeyEvent.javaadb shell input keyevent KEYCODE_HOME模拟按下 Home键 ,源码里面有定义:public static final int KEYCODE_HOME = 3;因此可以将命令中的 KEYCODE_HOME替换为 3input tap ,对屏幕发送一个触摸事件adb shell input tap 500 500点击屏幕上坐标为 500 500的位置input swipe ,滑动事件adb shell input swipe 从右往左滑动屏幕如果版本不低于 4.4 ,可以模拟长按事件adb shell input swipe 2000其实就是在小的距离内,在较长的持续时间内进行滑动,最后表现出来的结果就是长按动作到这里会发现,MonkeyRunner能做到的事情,通过 adb命令都可以做得到,如果进行封装,会比 MR做得更好。screencap截图命令adb shell screencap -p /sdcard/screen.png截屏,保存至 sdcard目录screenrecord4.4新增的录制命令adb shell screenrecord sdcard/record.mp4执行命令后操作手机,ctrl + c结束录制,录制结果保存至 sdcarduiautomator执行 UI automation tests ,获取当前界面的控件信息runtest:executes UI automation tests RunTestCommand.javadump:获取控件信息,DumpCommand.java[xuxu:~]$ adb shell uiautomator dump UI hierchary dumped to:/storage/emulated/legacy/window_dump.xml不加 [file]选项时,默认存放在 sdcard下ime输入法,[xuxu:~]$ adb shell ime list -s com.google.android.inputmethod.pinyin/.PinyinIMEcom.baidu.input_mi/.ImeService列出设备上的输入法[xuxu:~]$ adb shell ime set com.baidu.input_mi/.ImeServiceInput methodcom.baidu.input_mi/.ImeServiceselected选择输入法wm[xuxu:~]$ adb shell wm sizePhysical size: x1920获取设备分辨率monkeyadb shell monkey -p com.android.settings 1000settingsadb shell settings put global wifi_on 1dumpsysadb shell dumpsys | findstr DUMPlog这个命令很有意思,可以在 logcat里面打印你设定的信息,具体用途自己思考!adb shelllog -p d -t xuxu "test adb shell log"-p:优先级,-t:tag,标签,后面加上 message[xuxu:~]$ adb logcat -v time -s xuxu --------- beginning of /dev/log/system--------- beginning of /dev/log/main05-15 13:57:10.286 D/xuxu(12646): test adb shell loggetprop查看 Android设备的参数信息,只运行 adb shell getprop,结果以 key : value键值对的形式显示,如要获取某个 key的值:adb shell getprop ro.build.version.sdk获取设备的 sdk版本linux命令操作你的 Android设备,常用到的命令,只列出,不详解!cat、cd、chmod、cp、date、df、du、grep、kill、ln、ls、lsof、netstat、ping、ps、rm、rmdir、top、touch、重定向符号 "&" "&&"、管道 "|"有些可能需要使用 busybox ,另外建议 windows下安装一个 Cygwin ,没用过的请百度百科CygwinEND补充一个引号的用途:场景1、在 PC端执行 monkey命令,将信息保存至 D盘 monkey.log,会这么写:adb shell monkey -p com.android.settings5000 & d:\monkey.log场景2、在 PC端执行 monkey命令,将信息保存至手机的 Sdcard,可能会这么写:adb shell monkey -p com.android.settings5000 & sdcard/monkey.log这里肯定会报错,因为最终是写向了 PC端当前目录的 sdcard目录下,而非写向手机的 Sdcard这里需要用上引号:adbshell"monkey -p com.android.settings 5000 &sdcard/monkey.log"对这些命令都熟悉之后,那么接下来就是综合对编程语言的应用,思考如何用语言去处理这些命令,使得这些命令更加的方便于测试工作。本文转载自:https://testerhome.com/topics/1462Testin云测送大家一波超级福利!①价值5000元的Testin专属测试大礼包(包含120分钟自动化测试、120分钟远程真机调试、每日免费使用1次标准兼容测试、每日免费使用1次安全测试);②原51testing产品总监陈霁老师16年测试工作总结精华 -《软件测试入门必读》课程。如何获取福利?登陆或者注册您的Testin账号进行企业认证,完成认证自动获得福利大礼包,认证请戳——& http://www.testin.cn本文由百家号作者上传并发布,百家号仅提供信息发布平台。文章仅代表作者个人观点,不代表百度立场。未经作者许可,不得转载。冰晶蜂皇百家号最近更新:简介:欢迎关注巴拉卦神,关注娱乐,关注我作者最新文章相关文章> 出现failed
热门文章热门标签
08月31日 |
08月31日 |
08月31日 |
08月31日 |
08月31日 |
08月31日 |
08月31日 |
08月31日 |此文章内容整合自网络,欢迎转载。
我相信做Android开发的朋友都用过ADB命令,但是也只是限于安装应用push文件和设备重启相关,根深的也不知道了,其实我们完全可以了解多一点,有一些不常用的场景我们至少应该知道它可以做到,比如,我们知道adb install 却不知道adb shell am start。前者是用来安装软件,后者用来打开软件,后者的一个使用场景让我对他重视:公司定制Android系统,在调试屏幕的时候要看是否满屏验证驱动是否正常,比较麻烦的做法是要拿到Android开发者手里用eclipse或者其他ide安装打开。显然相对于驱动人员连上数据线使用adb命令要复杂得多。因此,了解多一点还是很有必要的。
接下来可能说的比较繁琐,我尽量说简单点,请耐心看完。
Adb的全称为Android Debug Bridge:android调试桥梁,下图为Android官方对adb的介绍:
可以看出,Android的初衷是用adb这样的一个工具来协助开发人员在开发android应用的过程中更快更好的调试apk,因此adb具有安装卸载apk、拷贝推送文件、查看设备硬件信息、查看应用程序占用资源、在设备执行shell命令等功能;
我们可以在android sdk安装目录的platform-tools目录下找到adb工具;
为了方便理解,我们从三个指令入手,我们经常会用到adb start-server,adb devices,adb kill-server。
然后我们经常会看到这样的输出界面:
C:\Users\dell&adb devices
List of devices attached
* daemon not running. starting it now at tcp:5037 *
* daemon started successfully *
于是这里有三点疑问,为什么是server,server对应的是服务器或者服务端吧?如果手机是客户端,服务端是不是指电脑上开启的服务。还有这个呆萌(daemon )又是啥?
ADB是一个C/S架构的应用程序,由三部分组成:
运行在pc端的adb client:
命令行程序”adb”用于从shell或脚本中运行adb命令。首先,“adb”程序尝试定位主机上的ADB服务器,如果找不到ADB服务器,“adb”程序自动启动一个ADB服务器。接下来,当设备的adbd和pc端的adb server建立连接后,adb client就可以向ADB servcer发送服务请求;
运行在pc端的adb server:
ADB Server是运行在主机上的一个后台进程。它的作用在于检测USB端口感知设备的连接和拔除,以及模拟器实例的启动或停止,ADB Server还需要将adb client的请求通过usb或者tcp的方式发送到对应的adbd上;
运行在设备端的常驻进程adb demon
程序“adbd”作为一个后台进程在Android设备或模拟器系统中运行。它的作用是连接ADB服务器,并且为运行在主机上的客户端提供一些服务;
adb能做什么?答案是所有能对手机的操作都能用adb实现。也就是说如果你玩的6,你就是触摸屏完全坏了,显示屏完全坏了,就只是给你一个主板,你照样能完成你要做的动作。当然在一般场景不推荐这样做,效率优先嘛。
接下来的内容是转自github上一位大牛的,如有侵权请告知,立即删除;
adb 命令的基本语法如下:
adb [-d|-e|-s ]
如果只有一个设备/模拟器连接时,可以省略掉 [-d|-e|-s ] 这一部分,直接使用 adb 。
为命令指定目标设备
如果有多个设备/模拟器连接,则需要为命令指定目标设备。
指定当前唯一通过 USB 连接的 Android 设备为命令目标
指定当前唯一运行的模拟器为命令目标
-s &serialNumber&
指定相应 serialNumber 号的设备/模拟器为命令目标
在多个设备/模拟器连接的情况下较常用的是 -s
参数,serialNumber 可以通过 adb devices 命令获取。如:
$ adb devices
List of devices attached
emulator-5554
10.129.164.6:5555
输出里的 cf264b8f、emulator-5554 和 10.129.164.6:5555 即为 serialNumber。
比如这时想指定 cf264b8f 这个设备来运行 adb 命令获取屏幕分辨率:
adb -s cf264b8f shell wm size
又如想给 10.129.164.6:5555 这个设备安装应用(这种形式的 serialNumber 格式为 :,一般为无线连接的设备或 Genymotion 等第三方 Android 模拟器):
adb -s 10.129.164.6:5555 install test.apk
遇到多设备/模拟器的情况均使用这几个参数为命令指定目标设备,下文中为简化描述,不再重复。
启动 adb server 命令:
adb start-server
(一般无需手动执行此命令,在运行 adb 命令时若发现 adb server 没有启动会自动调起。)
停止 adb server 命令:
adb kill-server
查看 adb 版本
adb version
Android Debug Bridge version 1.0.36
Revision 8f855a3d9b35-android
以 root 权限运行 adbd
adb 的运行原理是 PC 端的 adb server 与手机端的守护进程 adbd 建立连接,然后 PC 端的 adb client 通过 adb server 转发命令,adbd 接收命令后解析运行。
所以如果 adbd 以普通权限执行,有些需要 root 权限才能执行的命令无法直接用 adb xxx 执行。这时可以 adb shell 然后 su 后执行命令,也可以让 adbd 以 root 权限执行,这个就能随意执行高权限命令了。
正常输出:
restarting adbd as root
现在再运行 adb shell,看看命令行提示符是不是变成 # 了?
有些手机 root 后也无法通过 adb root 命令让 adbd 以 root 权限执行,比如三星的部分机型,会提示 adbd cannot run as root in production builds,此时可以先安装 adbd Insecure,然后 adb root 试试。
相应地,如果要恢复 adbd 为非 root 权限的话,可以使用 adb unroot 命令。
指定 adb server 的网络端口
adb -P &port& start-server
默认端口为 5037。
设备连接管理
查询已连接设备/模拟器
adb devices
输出示例:
List of devices attached
emulator-5554
10.129.164.6:5555
输出格式为 [serialNumber] [state],serialNumber 即我们常说的 SN,state 有如下几种:
offline —— 表示设备未连接成功或无响应。
device —— 设备已连接。注意这个状态并不能标识 Android 系统已经完全启动和可操作,在设备启动过程中设备实例就可连接到 adb,但启动完毕后系统才处于可操作状态。
no device —— 没有设备/模拟器连接。
以上输出显示当前已经连接了三台设备/模拟器,cf264b8f、emulator-5554 和 10.129.164.6:5555 分别是它们的 SN。从 emulator-5554 这个名字可以看出它是一个 Android 模拟器,而 10.129.164.6:5555 这种形为 : 的 serialNumber 一般是无线连接的设备或 Genymotion 等第三方 Android 模拟器。
常见异常输出:
没有设备/模拟器连接成功。
List of devices attached
设备/模拟器未连接到 adb 或无响应。
List of devices attached
通过 USB 连接来正常使用 adb 需要保证几点:
硬件状态正常。
包括 Android 设备处于正常开机状态,USB 连接线和各种接口完好。
Android 设备的开发者选项和 USB 调试模式已开启。
可以到「设置」-「开发者选项」-「Android 调试」查看。
如果在设置里找不到开发者选项,那需要通过一个彩蛋来让它显示出来:在「设置」-「关于手机」连续点击「版本号」7 次。
设备驱动状态正常。
这一点貌似在 Linux 和 Mac OS X 下不用操心,在 Windows 下有可能遇到需要安装驱动的情况,确认这一点可以右键「计算机」-「属性」,到「设备管理器」里查看相关设备上是否有黄色感叹号或问号,如果没有就说明驱动状态已经好了。否则可以下载一个手机助手类程序来安装驱动先。
通过 USB 线连接好电脑和设备后确认状态。
adb devices
如果能看到
xxxxxx device
说明连接成功。
无线连接(需要借助 USB 线)
除了可以通过 USB 连接设备与电脑来使用 adb,也可以通过无线连接——虽然连接过程中也有需要使用 USB 的步骤,但是连接成功之后你的设备就可以在一定范围内摆脱 USB 连接线的限制啦!
操作步骤:
将 Android 设备与要运行 adb 的电脑连接到同一个局域网,比如连到同一个 WiFi。
将设备与电脑通过 USB 线连接。
应确保连接成功(可运行 adb devices 看是否能列出该设备)。
让设备在 5555 端口监听 TCP/IP 连接:
adb tcpip 5555
断开 USB 连接。
找到设备的 IP 地址。
一般能在「设置」-「关于手机」-「状态信息」-「IP地址」找到,也可以使用下文里 查看设备信息 - IP 地址 一节里的方法用 adb 命令来查看。
通过 IP 地址连接设备。
adb connect &device-ip-address&
就是上一步中找到的设备 IP 地址。
确认连接状态。
adb devices
如果能看到
&device-ip-address&:5555 device
说明连接成功。
如果连接不了,请确认 Android 设备与电脑是连接到了同一个 WiFi,然后再次执行 adb connect &device-ip-address& 那一步;
如果还是不行的话,通过 adb kill-server 重新启动 adb 然后从头再来一次试试。
断开无线连接
adb disconnect &device-ip-address&
无线连接(无需借助 USB 线)
注:需要 root 权限。
上一节「无线连接(需要借助 USB 线)」是官方文档里介绍的方法,需要借助于 USB 数据线来实现无线连接。
既然我们想要实现无线连接,那能不能所有步骤下来都是无线的呢?答案是能的。
在 Android 设备上安装一个终端模拟器。
已经安装过的设备可以跳过此步。我使用的终端模拟器下载地址是:Terminal Emulator for Android Downloads
将 Android 设备与要运行 adb 的电脑连接到同一个局域网,比如连到同一个 WiFi。
打开 Android 设备上的终端模拟器,在里面依次运行命令:
setprop service.adb.tcp.port 5555
找到 Android 设备的 IP 地址。
一般能在「设置」-「关于手机」-「状态信息」-「IP地址」找到,也可以使用下文里 查看设备信息 - IP 地址 一节里的方法用 adb 命令来查看。
在电脑上通过 adb 和 IP 地址连接 Android 设备。
adb connect &device-ip-address&
就是上一步中找到的设备 IP 地址。
如果能看到 connected to :5555 这样的输出则表示连接成功。
有的设备,比如小米 5S + MIUI 8.0 + Android 6.0.1 MXB48T,可能在第 5 步之前需要重启 adbd 服务,在设备的终端模拟器上运行:
restart adbd
如果 restart 无效,尝试以下命令:
start adbd
查看应用列表
查看应用列表的基本命令格式是
[-f] [-d] [-e] [-s] [-3] [-i] [-u] [--user USER_ID] [FILTER]
即在 adb shell pm list packages 的基础上可以加一些参数进行过滤查看不同的列表,支持的过滤参数如下:
显示应用关联的 apk 文件
只显示 disabled 的应用
只显示 enabled 的应用
只显示系统应用
只显示第三方应用
显示应用的 installer
包含已卸载应用
包名包含 &FILTER& 字符串
adb shell pm list packages
输出示例:
package:com.android.smoketest
package:com.example.android.livecubes
package:com.android.providers.telephony
package:com.google.android.googlequicksearchbox
package:com.android.providers.calendar
package:com.android.providers.media
package:com.android.protips
package:com.android.documentsui
package:com.android.gallery
package:com.android.externalstorage
// other packages here
adb shell pm list packages -s
第三方应用
adb shell pm list packages -3
包名包含某字符串的应用
比如要查看包名包含字符串 mazhuang 的应用列表,命令:
adb shell pm list packages mazhuang
当然也可以使用 grep 来过滤:
adb shell pm list packages | grep mazhuang
命令格式:
adb install [-lrtsdg] &
adb install 后面可以跟一些可选参数来控制安装 APK 的行为,可用参数及含义如下:
将应用安装到保护目录 /mnt/asec
允许覆盖安装
允许安装 AndroidManifest.xml 里 application 指定 android:testOnly="true" 的应用
将应用安装到 sdcard
允许降级覆盖安装
授予所有运行时权限
运行命令后如果见到类似如下输出(状态为 Success)代表安装成功:
[100%] /data/local/tmp/1.apk
pkg: /data/local/tmp/1.apk
上面是当前最新版 v1.0.36 的 adb 的输出,会显示 push apk 文件到手机的进度百分比。
使用旧版本 adb 的输出则是这样的:
12040 KB/s ( bytes in 1.801s)
pkg: /data/local/tmp/SogouInput_android_v8.3_sweb.apk
而如果状态为 Failure 则表示安装失败,比如:
[100%] /data/local/tmp/map-.apk
pkg: /data/local/tmp/map-.apk
Failure [INSTALL_FAILED_ALREADY_EXISTS]
常见安装失败输出代码、含义及可能的解决办法如下:
INSTALL_FAILED_ALREADY_EXISTS
应用已经存在,或卸载了但没卸载干净
adb install 时使用 -r 参数,或者先 adb uninstall &packagename& 再安装
INSTALL_FAILED_INVALID_APK
无效的 APK 文件
INSTALL_FAILED_INVALID_URI
无效的 APK 文件名
确保 APK 文件名里无中文
INSTALL_FAILED_INSUFFICIENT_STORAGE
INSTALL_FAILED_DUPLICATE_PACKAGE
已经存在同名程序
INSTALL_FAILED_NO_SHARED_USER
请求的共享用户不存在
INSTALL_FAILED_UPDATE_INCOMPATIBLE
以前安装过同名应用,但卸载时数据没有移除;或者已安装该应用,但签名不一致
先 adb uninstall &packagename& 再安装
INSTALL_FAILED_SHARED_USER_INCOMPATIBLE
请求的共享用户存在但签名不一致
INSTALL_FAILED_MISSING_SHARED_LIBRARY
安装包使用了设备上不可用的共享库
INSTALL_FAILED_REPLACE_COULDNT_DELETE
替换时无法删除
INSTALL_FAILED_DEXOPT
dex 优化验证失败或空间不足
INSTALL_FAILED_OLDER_SDK
设备系统版本低于应用要求
INSTALL_FAILED_CONFLICTING_PROVIDER
设备里已经存在与应用里同名的 content provider
INSTALL_FAILED_NEWER_SDK
设备系统版本高于应用要求
INSTALL_FAILED_TEST_ONLY
应用是 test-only 的,但安装时没有指定 -t 参数
INSTALL_FAILED_CPU_ABI_INCOMPATIBLE
包含不兼容设备 CPU 应用程序二进制接口的 native code
INSTALL_FAILED_MISSING_FEATURE
应用使用了设备不可用的功能
INSTALL_FAILED_CONTAINER_ERROR
1. sdcard 访问失败;2. 应用签名与 ROM 签名一致,被当作内置应用。
1. 确认 sdcard 可用,或者安装到内置存储;2. 打包时不与 ROM 使用相同签名。
INSTALL_FAILED_INVALID_INSTALL_LOCATION
1. 不能安装到指定位置;2. 应用签名与 ROM 签名一致,被当作内置应用。
1. 切换安装位置,添加或删除 -s 参数;2. 打包时不与 ROM 使用相同签名。
INSTALL_FAILED_MEDIA_UNAVAILABLE
安装位置不可用
一般为 sdcard,确认 sdcard 可用或安装到内置存储
INSTALL_FAILED_VERIFICATION_TIMEOUT
验证安装包超时
INSTALL_FAILED_VERIFICATION_FAILURE
验证安装包失败
INSTALL_FAILED_PACKAGE_CHANGED
应用与调用程序期望的不一致
INSTALL_FAILED_UID_CHANGED
以前安装过该应用,与本次分配的 UID 不一致
清除以前安装过的残留文件
INSTALL_FAILED_VERSION_DOWNGRADE
已经安装了该应用更高版本
使用 -d 参数
INSTALL_FAILED_PERMISSION_MODEL_DOWNGRADE
已安装 target SDK 支持运行时权限的同名应用,要安装的版本不支持运行时权限
INSTALL_PARSE_FAILED_NOT_APK
指定路径不是文件,或不是以 .apk 结尾
INSTALL_PARSE_FAILED_BAD_MANIFEST
无法解析的 AndroidManifest.xml 文件
INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION
解析器遇到异常
INSTALL_PARSE_FAILED_NO_CERTIFICATES
安装包没有签名
INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES
已安装该应用,且签名与 APK 文件不一致
先卸载设备上的该应用,再安装
INSTALL_PARSE_FAILED_CERTIFICATE_ENCODING
解析 APK 文件时遇到 CertificateEncodingException
INSTALL_PARSE_FAILED_BAD_PACKAGE_NAME
manifest 文件里没有或者使用了无效的包名
INSTALL_PARSE_FAILED_BAD_SHARED_USER_ID
manifest 文件里指定了无效的共享用户 ID
INSTALL_PARSE_FAILED_MANIFEST_MALFORMED
解析 manifest 文件时遇到结构性错误
INSTALL_PARSE_FAILED_MANIFEST_EMPTY
在 manifest 文件里找不到找可操作标签(instrumentation 或 application)
INSTALL_FAILED_INTERNAL_ERROR
因系统问题安装失败
INSTALL_FAILED_USER_RESTRICTED
用户被限制安装应用
INSTALL_FAILED_DUPLICATE_PERMISSION
应用尝试定义一个已经存在的权限名称
INSTALL_FAILED_NO_MATCHING_ABIS
应用包含设备的应用程序二进制接口不支持的 native code
INSTALL_CANCELED_BY_USER
应用安装需要在设备上确认,但未操作设备或点了取消
在设备上同意安装
INSTALL_FAILED_ACWF_INCOMPATIBLE
应用程序与设备不兼容
does not contain AndroidManifest.xml
无效的 APK 文件
is not a valid zip file
无效的 APK 文件
设备未连接成功
先将设备与 adb 连接成功
unauthorized
设备未授权允许调试
error: device not found
没有连接成功的设备
先将设备与 adb 连接成功
protocol failure
设备已断开连接
先将设备与 adb 连接成功
Unknown option: -s
Android 2.2 以下不支持安装到 sdcard
不使用 -s 参数
No space left on device
Permission denied … sdcard …
sdcard 不可用
signatures do not match the previous ignoring!
已安装该应用且签名不一致
先卸载设备上的该应用,再安装
adb install 内部原理简介
adb install 实际是分三步完成:
push apk 文件到 /data/local/tmp。
调用 pm install 安装。
删除 /data/local/tmp 下的对应 apk 文件。
所以,必要的时候也可以根据这个步骤,手动分步执行安装过程。
adb uninstall [-k] &
&packagename& 表示应用的包名,-k 参数可选,表示卸载应用但保留数据和缓存目录。
命令示例:
adb uninstall com.qihoo360.mobilesafe
表示卸载 360 手机卫士。
清除应用数据与缓存
adb shell pm clear &packagename&
&packagename& 表示应用名包,这条命令的效果相当于在设置里的应用信息界面点击了「清除缓存」和「清除数据」。
命令示例:
adb shell pm clear com.qihoo360.mobilesafe
表示清除 360 手机卫士的数据和缓存。
查看前台 Activity
adb shell dumpsys activity activities | grep mFocusedActivity
输出示例:
mFocusedActivity: ActivityRecord{8079d7e u0 com.cyanogenmod.trebuchet/com.android.launcher3.Launcher t42}
其中的 com.cyanogenmod.trebuchet/com.android.launcher3.Launcher 就是当前处于前台的 Activity。
查看正在运行的 Services
adb shell dumpsys activity services [&]
&packagename& 参数不是必须的,指定 &packagename& 表示查看与某个包名相关的 Services,不指定表示查看所有 Services。
&packagename& 不一定要给出完整的包名,比如运行 adb shell dumpsys activity services org.mazhuang,那么包名 org.mazhuang.demo1、org.mazhuang.demo2 和 org.mazhuang123 等相关的 Services 都会列出来。
查看应用详细信息
adb shell dumpsys package &packagename&
输出中包含很多信息,包括 Activity Resolver Table、Registered ContentProviders、包名、userId、安装后的文件资源代码等路径、版本信息、权限信息和授予状态、签名版本信息等。
&packagename& 表示应用包名。
输出示例:
Activity Resolver Table:
Non-Data Actions:
android.intent.action.MAIN:
5b4cba8 org.mazhuang.guanggoo/.SplashActivity filter 5ec9dcc
Action: "android.intent.action.MAIN"
Category: "android.intent.category.LAUNCHER"
AutoVerify=false
Registered ContentProviders:
org.mazhuang.guanggoo/com.tencent.bugly.beta.utils.BuglyFileProvider:
Provider{7a3c394 org.mazhuang.guanggoo/com.tencent.bugly.beta.utils.BuglyFileProvider}
ContentProvider Authorities:
[org.mazhuang.guanggoo.fileProvider]:
Provider{7a3c394 org.mazhuang.guanggoo/com.tencent.bugly.beta.utils.BuglyFileProvider}
applicationInfo=ApplicationInfo{7754242 org.mazhuang.guanggoo}
Key Set Manager:
[org.mazhuang.guanggoo]
Signing KeySets: 501
Package [org.mazhuang.guanggoo] (c1d7f):
userId=10394
pkg=Package{55f714c org.mazhuang.guanggoo}
codePath=/data/app/org.mazhuang.guanggoo-2
resourcePath=/data/app/org.mazhuang.guanggoo-2
legacyNativeLibraryDir=/data/app/org.mazhuang.guanggoo-2/lib
primaryCpuAbi=null
secondaryCpuAbi=null
versionCode=74 minSdk=15 targetSdk=25
versionName=1.1.74
splits=[base]
apkSigningVersion=2
applicationInfo=ApplicationInfo{7754242 org.mazhuang.guanggoo}
flags=[ HAS_CODE ALLOW_CLEAR_USER_DATA ALLOW_BACKUP ]
privateFlags=[ RESIZEABLE_ACTIVITIES ]
dataDir=/data/user/0/org.mazhuang.guanggoo
supportsScreens=[small, medium, large, xlarge, resizeable, anyDensity]
timeStamp=2017-10-22 23:50:53
firstInstallTime=2017-10-22 23:50:25
lastUpdateTime=2017-10-22 23:50:55
installerPackageName=com.miui.packageinstaller
signatures=PackageSignatures{af09595 [53c7caa2]}
installPermissionsFixed=true installStatus=1
pkgFlags=[ HAS_CODE ALLOW_CLEAR_USER_DATA ALLOW_BACKUP ]
requested permissions:
android.permission.READ_PHONE_STATE
android.permission.INTERNET
android.permission.ACCESS_NETWORK_STATE
android.permission.ACCESS_WIFI_STATE
android.permission.READ_LOGS
android.permission.WRITE_EXTERNAL_STORAGE
android.permission.READ_EXTERNAL_STORAGE
install permissions:
android.permission.INTERNET: granted=true
android.permission.ACCESS_NETWORK_STATE: granted=true
android.permission.ACCESS_WIFI_STATE: granted=true
User 0: ceDataInode=1155675 installed=true hidden=false suspended=false stopped=true notLaunched=false enabled=0
gids=[3003]
runtime permissions:
android.permission.READ_EXTERNAL_STORAGE: granted=true
android.permission.READ_PHONE_STATE: granted=true
android.permission.WRITE_EXTERNAL_STORAGE: granted=true
User 999: ceDataInode=0 installed=false hidden=false suspended=false stopped=true notLaunched=true enabled=0
gids=[3003]
runtime permissions:
Dexopt state:
[org.mazhuang.guanggoo]
Instruction Set: arm64
path: /data/app/org.mazhuang.guanggoo-2/base.apk
status: /data/app/org.mazhuang.guanggoo-2/oat/arm64/base.odex [compilation_filter=speed-profile, status=kOatUpToDa
与应用交互
主要是使用 am &command& 命令,常用的 &command& 如下:
start [options] &INTENT&
启动 &INTENT& 指定的 Activity
startservice [options] &INTENT&
启动 &INTENT& 指定的 Service
broadcast [options] &INTENT&
发送 &INTENT& 指定的广播
force-stop &packagename&
停止 &packagename& 相关的进程
&INTENT& 参数很灵活,和写 Android 程序时代码里的 Intent 相对应。
用于决定 intent 对象的选项如下:
-a &ACTION&
指定 action,比如 android.intent.action.VIEW
-c &CATEGORY&
指定 category,比如 android.intent.category.APP_CONTACTS
-n &COMPONENT&
指定完整 component 名,用于明确指定启动哪个 Activity,如 com.example.app/.ExampleActivity
&INTENT& 里还能带数据,就像写代码时的 Bundle 一样:
--esn &EXTRA_KEY&
null 值(只有 key 名)
–es &EXTRA_KEY& &EXTRA_STRING_VALUE&`
--ez &EXTRA_KEY& &EXTRA_BOOLEAN_VALUE&
boolean 值
--ei &EXTRA_KEY& &EXTRA_INT_VALUE&
integer 值
--el &EXTRA_KEY& &EXTRA_LONG_VALUE&
--ef &EXTRA_KEY& &EXTRA_FLOAT_VALUE&
--eu &EXTRA_KEY& &EXTRA_URI_VALUE&
--ecn &EXTRA_KEY& &EXTRA_COMPONENT_NAME_VALUE&
component name
--eia &EXTRA_KEY& &EXTRA_INT_VALUE&[,&EXTRA_INT_VALUE...]
integer 数组
--ela &EXTRA_KEY& &EXTRA_LONG_VALUE&[,&EXTRA_LONG_VALUE...]
调起 Activity
命令格式:
adb shell am start [options] &
adb shell am start -n com.tencent.mm/.ui.LauncherUI
表示调起微信主界面。
adb shell am start -n org.mazhuang.boottimemeasure/.MainActivity --es "toast" "hello, world"
表示调起 org.mazhuang.boottimemeasure/.MainActivity 并传给它 string 数据键值对 toast - hello, world。
调起 Service
命令格式:
adb shell am startservice [options] &
adb shell am startservice -n com.tencent.mm/.plugin.accountsync.model.AccountAuthenticatorService
表示调起微信的某 Service。
命令格式:
adb shell am broadcast [options] &
可以向所有组件广播,也可以只向指定组件广播。
例如,向所有组件广播 BOOT_COMPLETED:
adb shell am broadcast -a android.intent.action.BOOT_COMPLETED
又例如,只向 org.mazhuang.boottimemeasure/.BootCompletedReceiver 广播 BOOT_COMPLETED:
adb shell am broadcast -a android.intent.action.BOOT_COMPLETED -n org.mazhuang.boottimemeasure/.BootCompletedReceiver
这类用法在测试的时候很实用,比如某个广播的场景很难制造,可以考虑通过这种方式来发送广播。
既能发送系统预定义的广播,也能发送自定义广播。如下是部分系统预定义广播及正常触发时机:
android.net.conn.CONNECTIVITY_CHANGE
网络连接发生变化
android.intent.action.SCREEN_ON
android.intent.action.SCREEN_OFF
android.intent.action.BATTERY_LOW
电量低,会弹出电量低提示框
android.intent.action.BATTERY_OKAY
电量恢复了
android.intent.action.BOOT_COMPLETED
设备启动完毕
android.intent.action.DEVICE_STORAGE_LOW
存储空间过低
android.intent.action.DEVICE_STORAGE_OK
存储空间恢复
android.intent.action.PACKAGE_ADDED
安装了新的应用
android.net.wifi.STATE_CHANGE
WiFi 连接状态发生变化
android.net.wifi.WIFI_STATE_CHANGED
WiFi 状态变为启用/关闭/正在启动/正在关闭/未知
android.intent.action.BATTERY_CHANGED
电池电量发生变化
android.intent.action.INPUT_METHOD_CHANGED
系统输入法发生变化
android.intent.action.ACTION_POWER_CONNECTED
外部电源连接
android.intent.action.ACTION_POWER_DISCONNECTED
外部电源断开连接
android.intent.action.DREAMING_STARTED
系统开始休眠
android.intent.action.DREAMING_STOPPED
系统停止休眠
android.intent.action.WALLPAPER_CHANGED
壁纸发生变化
android.intent.action.HEADSET_PLUG
android.intent.action.MEDIA_UNMOUNTED
卸载外部介质
android.intent.action.MEDIA_MOUNTED
挂载外部介质
android.os.action.POWER_SAVE_MODE_CHANGED
省电模式开启
(以上广播均可使用 adb 触发)
强制停止应用
adb shell am force-stop &
命令示例:
adb shell am force-stop com.qihoo360.mobilesafe
表示停止 360 安全卫士的一切进程与服务。
复制设备里的文件到电脑
adb pull & [电脑上的目录]
其中 电脑上的目录 参数可以省略,默认复制到当前目录。
adb pull /sdcard/sr.mp4 ~/tmp/
小技巧:设备上的文件路径可能需要 root 权限才能访问,如果你的设备已经 root 过,可以先使用 adb shell 和 su 命令在 adb shell 里获取 root 权限后,先 cp /path/on/device /sdcard/filename 将文件复制到 sdcard,然后 adb pull /sdcard/filename /path/on/pc。
复制电脑里的文件到设备
adb push & &
adb push ~/sr.mp4 /sdcard/
小技巧:设备上的文件路径普通权限可能无法直接写入,如果你的设备已经 root 过,可以先 adb push /path/on/pc /sdcard/filename,然后 adb shell 和 su 在 adb shell 里获取 root 权限后,cp /sdcard/filename /path/on/device。
模拟按键/输入
在 adb shell 里有个很实用的命令叫 input,通过它可以做一些有趣的事情。
input 命令的完整 help 信息如下:
Usage: input [&source&] &command& [&arg&...]
The sources are:
touchnavigation
touchscreen
The commands and default sources are:
text &string& (Default: touchscreen)
keyevent [--longpress] &key code number or name& ... (Default: keyboard)
tap &x& &y& (Default: touchscreen)
swipe &x1& &y1& &x2& &y2& [duration(ms)] (Default: touchscreen)
press (Default: trackball)
roll &dx& &dy& (Default: trackball)
比如模拟点击://在屏幕上点击坐标点x=50
y=250的位置。
adb shell input tap 50 250
比如使用 adb shell input keyevent
命令,不同的 keycode 能实现不同的功能,完整的 keycode 列表详见 KeyEvent,摘引部分我觉得有意思的如下:
打开拨号应用
拍照(需要在相机应用里)
打开浏览器
播放下一首
播放上一首
移动光标到行首或列表顶部
移动光标到行末或列表底部
打开系统设置
打开联系人
打开计算器
降低屏幕亮度
提高屏幕亮度
打开语音助手
如果没有 wakelock 则让系统休眠
下面是 input 命令的一些用法举例。
db shell input keyevent 26
执行效果相当于按电源键。
adb shell input keyevent 82
adb shell input keyevent 3
adb shell input keyevent 4
增加音量:
adb shell input keyevent 24
降低音量:
adb shell input keyevent 25
adb shell input keyevent 164
播放/暂停:
adb shell input keyevent 85
停止播放:
adb shell input keyevent 86
播放下一首:
adb shell input keyevent 87
播放上一首:
adb shell input keyevent 88
恢复播放:
adb shell input keyevent 126
暂停播放:
adb shell input keyevent 127
点亮/熄灭屏幕
可以通过上文讲述过的模拟电源键来切换点亮和熄灭屏幕,但如果明确地想要点亮或者熄灭屏幕,那可以使用如下方法。
点亮屏幕:
adb shell input keyevent 224
熄灭屏幕:
adb shell input keyevent 223
如果锁屏没有密码,是通过滑动手势解锁,那么可以通过 input swipe 来解锁。
命令(参数以机型 Nexus 5,向上滑动手势解锁举例):
adb shell input swipe 300 1000 300 500
分别表示起始点x坐标 起始点y坐标 结束点x坐标 结束点y坐标。
在焦点处于某文本框时,可以通过 input 命令来输入文本。
adb shell input text hello
现在 hello 出现在文本框了。
Android 系统的日志分为两部分,底层的 Linux 内核日志输出到 /proc/kmsg,Android 的日志输出到 /dev/log。
Android 日志
命令格式:
[adb] logcat [&option&] ... [&filter-spec&] ...
常用用法列举如下:
按级别过滤日志
Android 的日志分为如下几个优先级(priority):
V —— Verbose(最低,输出得最多)
D —— Debug I —— Info
W —— Warning
E —— Error
F—— Fatal
S —— Silent(最高,啥也不输出)
按某级别过滤日志则会将该级别及以上的日志输出。
比如,命令:
adb logcat *:W
会将 Warning、Error、Fatal 和 Silent 日志输出。
(注: 在 macOS 下需要给 :W 这样以
作为 tag 的参数加双引号,如 adb logcat “:W”,不然会报错 no matches found: :W。)
按 tag 和级别过滤日志
&filter-spec& 可以由多个 &tag&[:priority] 组成。
比如,命令:
adb logcat ActivityManager:I MyApp:D *:S
表示输出 tag ActivityManager 的 Info 以上级别日志,输出 tag MyApp 的 Debug 以上级别日志,及其它 tag 的 Silent 级别日志(即屏蔽其它 tag 日志)。
可以用 adb logcat -v &format& 选项指定日志输出格式。
日志支持按以下几种 &format&:
默认格式。格式为:
&priority&/&tag&(&pid&): &message&
D/HeadsetStateMachine( 1785): Disconnected process message: 10, size: 0
&priority&(&pid&) &message&
D( 1785) Disconnected process message: 10, size: 0
(HeadsetStateMachine)
&priority&/&tag&: &message&
D/HeadsetStateMachine: Disconnected process message: 10, size: 0
Disconnected process message: 10, size: 0
&datetime& &priority&/&tag&(&pid&): &message&
08-28 22:39:39.974 D/HeadsetStateMachine( 1785): Disconnected process message: 10, size: 0
threadtime
&datetime& &pid& &tid& &priority& &tag&: &message&
08-28 22:39:39.974
D HeadsetStateMachine: Disconnected process message: 10, size: 0
[ &datetime& &pid&:&tid& &priority&/&tag& ] &message&
[ 08-28 22:39:39.974
D/HeadsetStateMachine ] Disconnected process message: 10, size: 0
指定格式可与上面的过滤同时使用。比如:
adb logcat -v long ActivityManager:I *:S
adb logcat -c
adb shell dmesg
输出示例:
&6&[] PM: noirq resume of devices complete after 0.982 msecs
&6&[] PM: early resume of devices complete after 0.838 msecs
&6&[] PM: resume of devices complete after 68.106 msecs
&4&[] Restarting tasks ... done.
&6&[] PM: suspend exit 2016-08-28 13:31:32. UTC
&6&[] PM: suspend entry 2016-08-28 13:31:32. UTC
&6&[] PM: Syncing filesystems ... done.
中括号里的 [] 代表内核开始启动后的时间,单位为秒。
通过内核日志我们可以做一些事情,比如衡量内核启动时间,在系统启动完毕后的内核日志里找到 Freeing init memory 那一行前面的时间就是。
查看设备信息
adb shell getprop ro.product.model
输出示例:
adb shell dumpsys battery
输入示例:
Current Battery Service state:
AC powered: false
USB powered: true
Wireless powered: false
present: true
scale: 100
voltage: 3872
temperature: 280
technology: Li-poly
其中 scale 代表最大电量,level 代表当前电量。上面的输出表示还剩下 44% 的电量。
屏幕分辨率
adb shell wm size
输出示例:
Physical size: 1080x1920
该设备屏幕分辨率为 1080px * 1920px。
如果使用命令修改过,那输出可能是:
Physical size: 1080x1920
Override size: 480x1024
表明设备的屏幕分辨率原本是 1080px * 1920px,当前被修改为 480px * 1024px。
adb shell wm density
输出示例:
Physical density: 420
该设备屏幕密度为 420dpi。
如果使用命令修改过,那输出可能是:
Physical density: 480
Override density: 160
表明设备的屏幕密度原来是 480dpi,当前被修改为 160dpi。
显示屏参数
adb shell dumpsys window displays
输出示例:
WINDOW MANAGER DISPLAY CONTENTS (dumpsys window displays)
Display: mDisplayId=0
init=1080x1920 420dpi cur=1080x1920 app=1080x1794 rng=1080x1017-1810x1731
deferred=false layoutNeeded=false
其中 mDisplayId 为 显示屏编号,init 是初始分辨率和屏幕密度,app 的高度比 init 里的要小,表示屏幕底部有虚拟按键,高度为 1920 - 1794 = 126px 合 42dp。
android_id
adb shell settings get secure android_id
输出示例:
51b6be48bac8c569
在 Android 4.4 及以下版本可通过如下命令获取 IMEI:
adb shell dumpsys iphonesubinfo
输出示例:
Phone Subscriber Info:
Phone Type = GSM
Device ID = 041
其中的 Device ID 就是 IMEI。
而在 Android 5.0 及以上版本里这个命令输出为空,得通过其它方式获取了(需要 root 权限):
service call iphonesubinfo 1
输出示例:
Result: Parcel(
'........8.6.0.9.'
0x: 37 .5.0.2.7.7.8.5.'
把里面的有效内容提取出来就是 IMEI 了,比如这里的是 041。
参考:adb shell dumpsys iphonesubinfo not working since Android 5.0 Lollipop
Android 系统版本
adb shell getprop ro.build.version.release
输出示例:
每次想知道设备的 IP 地址的时候都得「设置」-「关于手机」-「状态信息」-「IP地址」很烦对不对?通过 adb 可以方便地查看。
adb shell ifconfig | grep Mask
输出示例:
:10.130.245.230
:255.255.255.252
:127.0.0.1
:255.0.0.0
那么 10.130.245.230 就是设备 IP 地址。
在有的设备上这个命令没有输出,如果设备连着 WiFi,可以使用如下命令来查看局域网 adb shell ifconfig wlan0例:
wlan0: ip 10.129.160.99 mask 255.255.240.0 flags [up broadcast running multicast]
Link encap:UNSPEC
inet addr:10.129.168.57
Bcast:10.129.175.255
Mask:255.255.240.0
inet6 addr: fe80:2eff:fe68:b6b6/64 Scope: Link
UP BROADCAST RUNNING MULTICAST
RX packets:496520 errors:0 dropped:0 overruns:0 frame:0
TX packets:68215 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:3000
RX bytes: TX bytes:8311736
如果以上命令仍然不能得到期望的信息,那可以试试以下命令(部分系统版本里可用):
adb shell netcfg
输出示例:
10.129.160.99/20
0x:a9:d0:17:42:4d
127.0.0.1/8
0x 00:00:00:00:00:00
0x fa:a9:d0:17:42:4d
0x 00:00:00:00:00:00
0x 00:00:00:00:00:00
0x 00:00:00:00:00:00
0x 00:00:00:00:00:00
0x 00:00:00:00:00:00
0x 00:00:00:00:00:00
0x 00:00:00:00:00:00
0x 00:00:00:00:00:00
0x 00:00:00:00:00:00
rev_rmnet3 DOWN
0xe:b7:e4:2e:17:58
rev_rmnet2 DOWN
0xe:f0:c8:bf:7a:cf
rev_rmnet4 DOWN
0x:c0:3b:6b:c4:1f
rev_rmnet6 DOWN
0x 66:bb:5d:64:2e:e9
rev_rmnet5 DOWN
0xe:1b:eb:b9:23:a0
rev_rmnet7 DOWN
0xa:d9:f6:81:40:5a
rev_rmnet8 DOWN
0xe:e2:a9:bb:d0:1b
rev_rmnet0 DOWN
0x fe:65:d0:ca:82:a9
rev_rmnet1 DOWN
0x da:d8:e8:4f:2e:fe
可以看到网络连接名称、启用状态、IP 地址和 Mac 地址等信息。
adb shell cat /sys/class/net/wlan0/address
输出示例:
:a9:d0:17:42:4d
这查看的是局域网 Mac 地址,移动网络或其它连接的信息可以通过前面的小节「IP 地址」里提到的 adb shell netcfg 命令来查看。
adb shell cat /proc/cpuinfo
输出示例:
: ARMv7 Processor rev 0 (v7l)
: swp half thumb fastmult vfp edsp neon vfpv3 tls vfpv4 idiva idivt
CPU implementer : 0x51
CPU architecture: 7
CPU variant
CPU revision
: Qualcomm MSM 8974 HAMMERHEAD (Flattened Device Tree)
这是 Nexus 5 的 CPU 信息,我们从输出里可以看到使用的硬件是 Qualcomm MSM 8974,processor 的编号是 0 到 3,所以它是四核的,采用的架构是 ARMv7 Processor rev 0 (v71)。
adb shell cat /proc/meminfo
输出示例:
1027424 kB
SwapCached:
Active(anon):
Inactive(anon):
Active(file):
Inactive(file):
Unevictable:
HighTotal:
SwapTotal:
Writeback:
AnonPages:
SReclaimable:
SUnreclaim:
KernelStack:
PageTables:
NFS_Unstable:
WritebackTmp:
CommitLimit:
Committed_AS:
VmallocTotal:
VmallocUsed:
VmallocChunk:
其中,MemTotal 就是设备的总内存,MemFree 是当前空闲内存。
更多硬件与系统属性
设备的更多硬件与系统属性可以通过如下命令查看:
adb shell cat /system/build.prop
这会输出很多信息,包括前面几个小节提到的「型号」和「Android 系统版本」等。
输出里还包括一些其它有用的信息,它们也可通过 adb shell getprop &属性名& 命令单独查看,列举一部分属性如下:
ro.build.version.sdk
ro.build.version.release
Android 系统版本
ro.build.version.security_patch
Android 安全补丁程序级别
ro.product.model
ro.product.brand
ro.product.name
ro.product.board
处理器型号
ro.product.cpu.abilist
CPU 支持的 abi 列表[节注一]
persist.sys.isUsbOtgEnabled
是否支持 OTG
dalvik.vm.heapsize
每个应用程序的内存上限
ro.sf.lcd_density
一些小厂定制的 ROM 可能修改过 CPU 支持的 abi 列表的属性名,如果用 ro.product.cpu.abilist 属性名查找不到,可以这样试试:
adb shell cat /system/build.prop | grep ro.product.cpu.abi
示例输出:
ro.product.cpu.abi=armeabi-v7a
ro.product.cpu.abi2=armeabi
注: 修改设置之后,运行恢复命令有可能显示仍然不太正常,可以运行 adb reboot 重启设备,或手动重启。
修改设置的原理主要是通过 settings 命令修改 /data/data/com.android.providers.settings/databases/settings.db 里存放的设置值。
adb shell wm size 480x1024
表示将分辨率修改为 480px * 1024px。
恢复原分辨率命令:
adb shell wm size reset
adb shell wm density 160
表示将屏幕密度修改为 160dpi。
恢复原屏幕密度命令:
adb shell wm density reset
adb shell wm overscan 0,0,0,200
四个数字分别表示距离左、上、右、下边缘的留白像素,以上命令表示将屏幕底部 200px 留白。
恢复原显示区域命令:
adb shell wm overscan reset
关闭 USB 调试模式
adb shell settings put global adb_enabled 0
用命令恢复不了了,毕竟关闭了 USB 调试 adb 就连接不上 Android 设备了。
去设备上手动恢复吧:「设置」-「开发者选项」-「Android 调试」。
状态栏和导航栏的显示隐藏
本节所说的相关设置对应 Cyanogenmod 里的「扩展桌面」。
adb shell settings put global policy_control &key-values&
&key-values& 可由如下几种键及其对应的值组成,格式为 &key1&=&value1&:&key2&=&value2&。
immersive.full
immersive.status
隐藏状态栏
immersive.navigation
隐藏导航栏
immersive.preconfirms
这些键对应的值可则如下值用逗号组合:
packagename
-packagename
排除指定应用
adb shell settings put global policy_control immersive.full=*
表示设置在所有界面下都同时隐藏状态栏和导航栏。
adb shell settings put global policy_control immersive.status=com.package1,com.package2:immersive.navigation=apps,-com.package3
表示设置在包名为 com.package1 和 com.package2 的应用里隐藏状态栏,在除了包名为 com.package3 的所有应用里隐藏导航栏。
恢复正常模式
不想全屏了咋办呢?
adb shell settings put global policy_control null
截图保存到电脑:
adb exec-out screencap -p & sc.png
如果 adb 版本较老,无法使用 exec-out 命令,这时候建议更新 adb 版本。无法更新的话可以使用以下麻烦点的办法:
先截图保存到设备里:
adb shell screencap -p /sdcard/sc.png
然后将 png 文件导出到电脑:
adb pull /sdcard/sc.png
可以使用 adb shell screencap -h 查看 screencap 命令的帮助信息,下面是两个有意义的参数及含义:
指定保存文件为 png 格式
-d display-id
指定截图的显示屏编号(有多显示屏的情况下)
实测如果指定文件名以 .png 结尾时可以省略 -p 参数;否则需要使用 -p 参数。如果不指定文件名,截图文件的内容将直接输出到 stdout。
另外一种一行命令截图并保存到电脑的方法:
Linux 和 Windows
adb shell screencap -p | sed "s/\r$
adb shell screencap -p | gsed "s/\r$
这个方法需要用到 gnu sed 命令,在 Linux 下直接就有,在 Windows 下 Git 安装目录的 bin 文件夹下也有。如果确实找不到该命令,可以下载 sed for Windows 并将 sed.exe 所在文件夹添加到 PATH 环境变量里。
而在 Mac 下使用系统自带的 sed 命令会报错:
sed: RE error: illegal byte sequence
需要安装 gnu-sed,然后使用 gsed 命令:
brew install gnu-sed
录制屏幕以 mp4 格式保存到 /sdcard:
adb shell screenrecord /sdcard/filename.mp4
需要停止时按 Ctrl-C,默认录制时间和最长录制时间都是 180 秒。
如果需要导出到电脑:
adb pull /sdcard/filename.mp4
可以使用 adb shell screenrecord –help 查看 screenrecord 命令的帮助信息,下面是常见参数及含义:
–size WIDTHxHEIGHT
视频的尺寸,比如 ,默认是屏幕分辨率。
–bit-rate RATE
视频的比特率,默认是 4Mbps。
–time-limit TIME
录制时长,单位秒。
输出更多信息。
重新挂载 system 分区为可写
注:需要 root 权限。
/system 分区默认挂载为只读,但有些操作比如给 Android 系统添加命令、删除自带应用等需要对 /system 进行写操作,所以需要重新挂载它为可读写。
进入 shell 并切换到 root 用户权限。
查看当前分区挂载情况。
输出示例:
rootfs / rootfs ro,relatime 0 0
tmpfs /dev tmpfs rw,seclabel,nosuid,relatime,mode=755 0 0
devpts /dev/pts devpts rw,seclabel,relatime,mode=600 0 0
proc /proc proc rw,relatime 0 0
sysfs /sys sysfs rw,seclabel,relatime 0 0
selinuxfs /sys/fs/selinux selinuxfs rw,relatime 0 0
debugfs /sys/kernel/debug debugfs rw,relatime 0 0
none /var tmpfs rw,seclabel,relatime,mode=770,gid=1000 0 0
none /acct cgroup rw,relatime,cpuacct 0 0
none /sys/fs/cgroup tmpfs rw,seclabel,relatime,mode=750,gid=1000 0 0
none /sys/fs/cgroup/memory cgroup rw,relatime,memory 0 0
tmpfs /mnt/asec tmpfs rw,seclabel,relatime,mode=755,gid=1000 0 0
tmpfs /mnt/obb tmpfs rw,seclabel,relatime,mode=755,gid=1000 0 0
none /dev/memcg cgroup rw,relatime,memory 0 0
none /dev/cpuctl cgroup rw,relatime,cpu 0 0
none /sys/fs/cgroup tmpfs rw,seclabel,relatime,mode=750,gid=1000 0 0
none /sys/fs/cgroup/memory cgroup rw,relatime,memory 0 0
none /sys/fs/cgroup/freezer cgroup rw,relatime,freezer 0 0
/dev/block/platform/msm_sdcc.1/by-name/system /system ext4 ro,seclabel,relatime,data=ordered 0 0
/dev/block/platform/msm_sdcc.1/by-name/userdata /data ext4 rw,seclabel,nosuid,nodev,relatime,noauto_da_alloc,data=ordered 0 0
/dev/block/platform/msm_sdcc.1/by-name/cache /cache ext4 rw,seclabel,nosuid,nodev,relatime,data=ordered 0 0
/dev/block/platform/msm_sdcc.1/by-name/persist /persist ext4 rw,seclabel,nosuid,nodev,relatime,data=ordered 0 0
/dev/block/platform/msm_sdcc.1/by-name/modem /firmware vfat ro,context=u:object_r:firmware_file:s0,relatime,uid=1000,gid=1000,fmask=0337,dmask=0227,codepage=cp437,iocharset=iso8859-1,shortname=lower,errors=remount-ro 0 0
/dev/fuse /mnt/shell/emulated fuse rw,nosuid,nodev,relatime,user_id=1023,group_id=1023,default_permissions,allow_other 0 0
/dev/fuse /mnt/shell/emulated/0 fuse rw,nosuid,nodev,relatime,user_id=1023,group_id=1023,default_permissions,allow_other 0 0
找到其中我们关注的带 /system 的那一行:
/dev/block/platform/msm_sdcc.1/by-name/system /system ext4 ro,seclabel,relatime,data=ordered 0 0
重新挂载。
mount -o remount,rw -t yaffs2 /dev/block/platform/msm_sdcc.1/by-name/system /system
这里的 /dev/block/platform/msm_sdcc.1/by-name/system 就是我们从上一步的输出里得到的文件路径。
如果输出没有提示错误的话,操作就成功了,可以对 /system 下的文件为所欲为了。
查看连接过的 WiFi 密码
注:需要 root 权限。
cat /data/misc/wifi/*.conf
输出示例:
ssid="TP-LINK_9DFC"
scan_ssid=1
key_mgmt=WPA-PSK
group=CCMP TKIP
auth_alg=OPEN
priority=13893
ssid="TP-LINK_F11E"
key_mgmt=WPA-PSK
priority=17293
ssid 即为我们在 WLAN 设置里看到的名称,psk 为密码,key_mgmt 为安全加密方式。
设置系统日期和时间
注:需要 root 权限。
date -s 500
表示将系统日期和时间更改为 2016 年 08 月 23 日 13 点 15 分 00 秒。
adb reboot
检测设备是否已 root
此时命令行提示符是 $ 则表示没有 root 权限,是 # 则表示已 root。
使用 Monkey 进行压力测试
Monkey 可以生成伪随机用户事件来模拟单击、触摸、手势等操作,可以对正在开发中的程序进行随机压力测试。
简单用法:
adb shell monkey -p &packagename& -v 500
表示向 &packagename& 指定的应用程序发送 500 个伪随机事件。
Monkey 的详细用法参考 官方文档。
开启/关闭 WiFi
注:需要 root 权限。
有时需要控制设备的 WiFi 状态,可以用以下指令完成。
开启 WiFi:
adb shell svc wifi enable
关闭 WiFi:
adb shell svc wifi disable
若执行成功,输出为空;若未取得 root 权限执行此命令,将执行失败,输出 Killed。
刷机相关命令
重启到 Recovery 模式
adb reboot recovery
从 Recovery 重启到 Android
adb reboot
重启到 Fastboot 模式
adb reboot bootloader
如果我们下载了 Android 设备对应的系统更新包到电脑上,那么也可以通过 adb 来完成更新。
以 Recovery 模式下更新为例:
重启到 Recovery 模式。
adb reboot recovery
在设备的 Recovery 界面上操作进入 Apply update-Apply from ADB。
注:不同的 Recovery 菜单可能与此有差异,有的是一级菜单就有 Apply update from ADB。
通过 adb 上传和更新系统。
adb sideload &path-to-update.zip&
更多 adb shell 命令
Android 系统是基于 Linux 内核的,所以 Linux 里的很多命令在 Android 里也有相同或类似的实现,在 adb shell 里可以调用。本文档前面的部分内容已经用到了 adb shell 命令。
adb shell ps
S kthreadd
1538748 48896 ffffffff
S com.sohu.inputmethod.sogou:classic
1561916 59568 ffffffff
S org.mazhuang.boottimemeasure
b6f28340 R ps
各列含义:
查看实时资源占用情况
adb shell top
User 0%, System 6%, IOW 0%, IRQ 0%
User 3 + Nice 0 + Sys 21 + Idle 280 + IOW 0 + IRQ 0 + SIRQ 3 = 307
PID PR CPU% S
system_server
/system/bin/mpdecision
/sbin/adbd
19 1538748K
com.sohu.inputmethod.sogou:classic
18 1561916K
org.mazhuang.boottimemeasure
各列含义:
当前瞬间占用 CPU 百分比
进程状态(R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程)
Virtual Set Size 虚拟耗用内存(包含共享库占用的内存)
Resident Set Size 实际使用物理内存(包含共享库占用的内存)
调度策略优先级,SP_BACKGROUND/SPFOREGROUND
进程所有者的用户 ID
top 命令还支持一些命令行参数,详细用法如下:
Usage: top [ -m max_procs ] [ -n iterations ] [ -d delay ] [ -s sort_column ] [ -t ] [ -h ]
最多显示多少个进程
刷新多少次后退出
刷新时间间隔(单位秒,默认值 5)
按某列排序(可用 col 值:cpu, vss, rss, thr)
显示线程信息
显示帮助文档
查看进程 UID
有两种方案:
adb shell dumpsys package &packagename& | grep userId=
$ adb shell dumpsys package org.mazhuang.guanggoo | grep userId=
userId=10394
通过 ps 命令找到对应进程的 pid 之后 adb shell cat /proc/&pid&/status | grep Uid
$ adb shell
gemini:/ $ ps | grep org.mazhuang.guanggoo
1795812 78736 SyS_epoll_
S org.mazhuang.guanggoo
gemini:/ $ cat /proc/28635/status | grep Uid
gemini:/ $
如下是其它常用命令的简单描述,前文已经专门讲过的命令不再额外说明:
显示文件内容
改变文件的存取模式/访问权限
查看磁盘空间使用情况
杀死指定 PID 的进程
列举目录内容
挂载目录的查看和管理
移动或重命名文件
查看正在运行的进程
查看进程的资源占用情况
启动 adb server 失败
error: protocol fault (couldn't read status): No error
adb server 进程想使用的 5037 端口被占用。
找到占用 5037 端口的进程,然后终止它。以 Windows 下为例:
netstat -ano | findstr LISTENING
0.0.0.0:5037
这里 1548 即为进程 ID,用命令结束该进程:
taskkill /PID 1548
然后再启动 adb 就没问题了。
安卓测试常用的 ADB 命令大全,非常全!!!!!
学习前是不是得先看看 adb 具体是啥东西,好吧,网上一大堆,截取了部分如下:SDK的Tools文件夹下包含着Android模拟器操作的重要命令adb,adb的全称为(...
安卓adb是什么?ADB命令大全及使用教程
安卓系统的adb的全称为Android Debug Bridge,就是起到调试桥的作用,利用adb工具的前提是在手机上打开usb调试,然后通过数据线连接电脑。在电脑上使用命令模式来操作手机:重启、进入...
adb操作命令详大全&利用adb命令查看apk文件包名
adb是什么?:adb的全称为Android Debug
Bridge,就是起到调试桥的作用。通过adb我们可以在Eclipse中方面通过DDMS来调试android程序,说白了就是debug工具...
Android常用adb命令总结
针对移动端Android的测试,adb命令是很重要的一个点,必须将常用的adb命令熟记于心,将会为Android测试带来很大的方便,其中很多命令将会用于自动化测试的脚本当中。...
最近在做一个安卓相关的项目,其中要使用到adb命令,所以自己找网上的资料熟悉下,正好做一个总结:
Android 调试桥(adb)是多种用途的工具,该工具可以帮助你你管理设备或模拟器 的状态。
没有更多推荐了,}

我要回帖

更多关于 linux命令大全 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信