前几天被公司安排到一个做android Framework层的项目中,由于该项目需要经常使用adb进行获取设备信息,模拟发送广播等操作,在这个方面被他们无情的嘲笑了一番,痛定思痛,下狠心学习并总结一下adb常用指令和使用的一些技巧,方便自己记忆的同时,也希望能给遇到类似问题的童鞋一些帮助,避免像我一样被嘲笑。

    adb指令,可以通过adb help列出,用法也有:


1. 显示系统中全部Android平台:
     android list targets
 2. 显示系统中全部AVD(模拟器):
     android list avd
 3. 创建AVD(模拟器):
     android create avd --name 名称 --target 平台编号
 4. 启动模拟器:
     emulator -avd 名称 -sdcard ~/名称.img (-skin 1280x800)
 5. 删除AVD(模拟器):
     android delete avd --name 名称
 6. 创建SDCard:
     mksdcard 1024M ~/名称.img
 7. AVD(模拟器)所在位置:
     Linux(~/.android/avd)      Windows(C:\Documents and Settings\Administrator\.android\avd)
 8. 启动DDMS:
     ddms
 9. 显示当前运行的全部模拟器:
     adb devices
 10. 对某一模拟器执行命令:
       abd -s 模拟器编号 命令
 11. 安装应用程序:
       adb install -r 应用程序.apk
 12. 获取模拟器中的文件:
       adb pull <remote> <local>
 13. 向模拟器中写文件:
       adb push <local> <remote>
 14. 进入模拟器的shell模式:
       adb shell
 15. 启动SDK,文档,实例下载管理器:
       android
 16. 缷载apk包:
       adb shell
       cd data/app
       rm apk包
       exit
       adb uninstall apk包的主包名
       adb install -r apk包
 17. 查看adb命令帮助信息:
       adb help
 18. 在命令行中查看LOG信息:
       adb logcat -s 标签名
 android输出的每一条日志都有一个标记和优先级与其关联。
优先级是下面的字符,顺序是从低到高:
V — 明细 verbose(最低优先级)
D — 调试 debug
I — 信息 info
W — 警告 warn
E — 错误 error
F — 严重错误 fatal
S — 无记载 silent
adb logcat     //显示全部日志
adb logcat > c:\test.log //将日志保存到文件test.log
根据tag标记和级别过滤日志输出:
仅输出标记为“ActivityManager”且优先级大于等于“Info”和标记为“PowerManagerService”并且优先级大于等于“Debug”的日志:
adb logcat ActivityManager:I PowerManagerService:D *:S
注:*:S用于设置所有标记的日志优先级为S,这样可以确保仅输出符合条件的日志。
adb logcat *:W   //显示所有优先级大于等于“warning”的日志
adb logcat -s PowerManagerService   //显示PowerManagerService的日志信息
Logcat命令列表:
-d 将日志显示在控制台后退出
-c 清理已存在的日志
-f <filename> 将日志输出到文件
adb logcat -f /sdcard/test.txt
-v <format>设置日志输入格式控制输出字段,默认的是brief格式
brief — 显示优先级/标记和原始进程的PID (默认格式)
process — 仅显示进程PID
tag — 仅显示优先级/标记
thread — 仅显示进程:线程和优先级/标记
raw — 显示原始的日志信息,没有其他的元数据字段
time — 显示日期,调用时间,优先级/标记,PID
long —显示所有的元数据字段并且用空行分隔消息内容
adb logcat -v thread   //使用 thread 输出格式
注意-v 选项中只能指定一种格式。
-b <buffer>加载一个可使用的日志缓冲区供查看,默认值是main。
radio — 查看包含在无线/电话相关的缓冲区消息
events — 查看事件相关的消息
main — 查看主缓冲区 (默认缓冲区)
adb logcat -b radio     //查看radio缓冲区
 19. adb shell后面跟的命令主要来自:
       源码\system\core\toolbox目录和源码\frameworks\base\cmds目录。
 20. 删除系统应用:
       adb remount (重新挂载系统分区,使系统分区重新可写)。
       adb shell
       cd system/app
       rm *.apk
 21. 获取管理员权限:
       adb root
 22. 启动Activity:
     adb shell am start -n 包名/包名+类名(-n 类名,-a action,-d date,-m MIME-TYPE,-c category,-e 扩展数据,等)。
如:启动浏览器
# am start -n com.android.browser/com.android.browser.BrowserActivity


二、adb启动service:
$ adb shell
$ am startservice -n {包(package)名}/{包名}.{服务(service)名称}
如:启动自己应用中一个service
# am startservice -n com.android.traffic/com.android.traffic.maniservice


三、adb发送broadcast:
$ adb shell
$ am broadcast -a <广播动作>
如:发送一个网络变化的广播
# am broadcast -a android.net.conn.CONNECTIVITY_CHANGE
 
 23、发布端口:
     你可以设置任意的端口号,做为主机向模拟器或设备的请求端口。如: 
 adb forward tcp:5555 tcp:8000
 24、复制文件:
     你可向一个设备或从一个设备中复制文件, 
      复制一个文件或目录到设备或模拟器上: 
 adb push <source> <destination></destination></source> 
       如:adb push test.txt /tmp/test.txt 
      从设备或模拟器上复制一个文件或目录: 
      adb pull <source> <destination></destination></source> 
      如:adb pull /addroid/lib/libwebcore.so .
 25、搜索模拟器/设备的实例:
      取得当前运行的模拟器/设备的实例的列表及每个实例的状态: 
     adb devices
 26、查看bug报告: 
 adb bugreport 
 27、记录无线通讯日志:
     一般来说,无线通讯的日志非常多,在运行时没必要去记录,但我们还是可以通过命令,设置记录: 
     adb shell 
     logcat -b radio
 28、获取设备的ID和序列号:
      adb get-product 
      adb get-serialno
 29、访问数据库SQLite3
      adb shell 
      sqlite3
 #cd system/sd/data //进入系统内指定文件夹 
 #ls //列表显示当前文件夹内容 
 #rm -r xxx //删除名字为xxx的文件夹及其里面的所有文件 
 #rm xxx //删除文件xxx 
 #rmdir xxx //删除xxx的文件夹
 30、还有一些linux shell指令
 1.ps -aux 查看所有正在运行的进程


 ps | grep xxx 显示过滤指定名称的进程
 可是以上的命令在Android上,都不起作用! What?!!!Android不是基于Linux系统的吗?对,准确来说,Android是Google基于Linux的内核改造出来的。那也意味着,Android是一个Linux的修改版,这样子也解析了同样的命令,不能执行的问题了。


 对于前面提到的命令,我们可以这样子的命令来替代:


 ps 可以查看所有正在运行的进程


 ps xxx 显示过滤指定名称的进程
 和原来的Linux相比,貌似更人性化了,或者说,功能简洁了许多,毕竟Android的toolbox是为适应大多数移动设备而设计的。


 接着我们一起学习一下Android的ps命令参数: -t -x -P -p -c [pid|name]


 -t 显示进程下的线程列表
 -x 显示进程耗费的用户时间和系统时间,格式:(u:0, s:0),单位:秒(s)
 -P 显示调度策略,通常是bg或fg,当获取失败将会是un和er
 -p 显示进程的优先级和nice等级
 -c 显示进程耗费的CPU时间 (可能不兼容Android 4.0以前的老版本系统)
 [pid] 过滤指定的进程PID
 [name] 过滤指定的进程NAME
 2.getprop stopprop watchprop
 getprop [key]  取得对应的key的属性值
 getprop  列出所有配置属性值
 如果要修改属性的话,很简单,只需修改字典值就可以了,如:
 setprop [key] [value] 设置指定key的属性值;
 watchprops  监听系统属性的变化,如果期间系统的属性发生变化则把变化的值显示出来