1摘能、日志相關(guān):
adb logcat? ? //顯示全部日志
adb logcat > c:\test.log //將日志保存到文件test.log
從當(dāng)前開始顯示
? ? ? logcat 有緩存蚌铜,如果僅需要查看當(dāng)前開始的 log捅位,需要清空之前的抓韩。
? ? ? adb logcat -c && adb logcat
? ? ? adb logcat | grep MyApp
? ? ? adb logcat | grep -i myapp #忽略大小寫。
根據(jù)tag name過濾
adb logcat -s TAG_NAME
adb logcat -s TAG_NAME_1 TAG_NAME_2
#example
adb logcat -s TEST
adb logcat -s TEST MYAPP
優(yōu)先級(jí):
V — 細(xì)則 (最低優(yōu)先級(jí))
D — 調(diào)試
I — 信息
W — 警告
E — 錯(cuò)誤
F — 致命
S — 靜默 (最高優(yōu)先級(jí)钢属,不會(huì)打印任何信息)
使用grep過濾
這個(gè)很像在Linux上使用管道命令一樣必峰,需系統(tǒng)支持
adb logcat | grep "SEARCH_TERM"
adb logcat | grep "SEARCH_TERM_1\|SEARCH_TERM_2"
#example
adb logcat | grep "Exception"
adb logcat | grep "Exception\|Error"
清除日志塊
使用來清除舊的日志
adb logcat -c
基礎(chǔ)腳本:
1、啟動(dòng)adb服務(wù)
adb start-server
2僚祷、終止adb服務(wù)
adb kill-server
3佛致、進(jìn)入adb運(yùn)行環(huán)境
adb shell
4、獲取幫助 里面有adb的各種命令和參數(shù)的介紹
adb help
5辙谜、查看adb版本
adb version
6俺榆、以root權(quán)限重啟adb
adb root
7、將system分區(qū)重新掛在為可讀寫分區(qū)装哆,此命令在操作系統(tǒng)目錄時(shí)很重要
adb remount
8肋演、重啟設(shè)備,可選參數(shù)進(jìn)入bootloader(刷機(jī)模式)或recovery(恢復(fù)模式)
adb reboot [bootloader|recovery]
apk相關(guān):
1、安裝apk
adb install test.apk?-r 覆蓋安裝烂琴,保留數(shù)據(jù)和緩存文件? -d 解決低版本version問題? -s 安裝apk到sd卡
2、卸載apk
adb uninstall -k <package_name>
可選參數(shù)-k的作用為卸載軟件但是保留配置和緩存文件
3蜕乡、查看app相關(guān)所有信息奸绷,包括action,codepath,version,需要的權(quán)限等等信息
adb shell dumpsys package <package_name>
4、查看app的路徑
adb shell pm path <package_name>
查看了一個(gè)普通app的路徑层玲,如下号醉,位于data/app下面的普通app
package:/data/app/com.tencent.test-1/base.apk
5、查看apk的版本信息
adb shell dumpsys package <package_name> | grepversion
如果你得到的是下圖的兩個(gè)version版本辛块,則為系統(tǒng)app,下面是系統(tǒng)app本身的版本畔派,上面是升級(jí)之后的系統(tǒng)app的版本信息
versionCode=8 targetSdk=22? versionName=V0.08 versionCode=6targetSdk=22? versionName=V0.0
6、啟動(dòng)activity
查看:
adb shell dumpsys window | findstr mCurrentFocus ?命令查看當(dāng)前運(yùn)行的包名和Activity
adb shell am start -n <package_name>/.<activity_class_name>
C:\Users\lenovo>adb shell
venus:/ $ ^C
C:\Users\lenovo>adb shell dumpsys window | findstrmCurrentFocus
?mCurrentFocus=Window{3bd0b18 u0com.android.settings/com.asu.msettings.AsuSettingsActiv
C:\Users\lenovo>adb shell am start -ncom.android.settings/com.asu.msettings.AsuSettingsA
Starting: Intent { cmp=com.android.settings/com.asu.msettings.AsuSettingsActivityAlias}
6.16.
清楚應(yīng)用數(shù)據(jù)adb shell pm path <PACKAGE>
輸出安裝包的APK路徑
adb shell pm clear <PACKAGE>
刪除與包相關(guān)的所有數(shù)據(jù):清除數(shù)據(jù)和緩存
7润绵、獲得應(yīng)用的啟動(dòng)時(shí)間线椰,可以很方便地獲取應(yīng)用的啟動(dòng)時(shí)間
adb shell am start -W<package_name>/.<activity_class_name>
試驗(yàn)結(jié)果如下:
adb shell am start -Wcom.cc.test/com.painter.test.PainterMainActivity Starting: Intent {act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER]cmp=com.cc.test/com.painter.test.PainterMainActivity } Status: ok Activity:com.cc.test/com.painter.test.PainterMainActivity ThisTime: 355 TotalTime: 355WaitTime: 365 Complete
返回的幾個(gè)結(jié)果,以WaitTime為準(zhǔn)尘盼,返回的是從startActivity到應(yīng)用第一幀完全顯示的時(shí)間憨愉。
8烦绳、啟動(dòng)service,am的-n參數(shù)表示組件,-a參數(shù)表示命令配紫,-a后面的參數(shù)為manifest中定義的service的action
adb shell am startservice -n <package_name>/.<service_class_name>
也可:
adb shell am startservice -a "android.intent.action.CALL"
9径密、發(fā)送廣播
adb shell am broadcast -a "android.intent.action.AdupsFota.WriteCommandReceiver"
廣播可以帶上不同類型的參數(shù),–es為string參數(shù)類型,–ei為int參數(shù)類型,–ez為boolean參數(shù)類型
adb shell am broadcast -a "android.intent.action.AdupsFota.WriteCommandReceiver"--es test_string "this is test string"
10、查看某個(gè)app的進(jìn)程相關(guān)信息
10.1
adb shell ps <package_name|PID>
例如
adb shell ps com.ma.app:push USER? PID PPID VSIZE RSS WCHAN?? PC NAME u0_a116 5483 304 1776564 55112sys_epoll_ 00000000 S com.ma.app:push
小米手機(jī)上測(cè)試成功躺孝,在另外一個(gè)設(shè)備上享扔,如果ps后面的參數(shù)是包名則顯示不了進(jìn)程的詳細(xì)信息,參見下面的方式獲取
10.2
adb shell ps | grep <package_name>
11植袍、殺掉某個(gè)進(jìn)程惧眠,一般用于模擬某個(gè)bug復(fù)現(xiàn)
adb shell kill pid Number
12、查看某一個(gè)app的內(nèi)存占用
adb shell dumpsys meminfo <package_name|PID>
結(jié)果如下奋单,其中的Heap size包括了Dalvik Heap和Native Heap,平時(shí)我們所說的內(nèi)存限制指的是Dalvik Heap锉试。
?Pss PrivatePrivate Swapped? Heap? Heap?Heap???? Total Dirty CleanDirty? Size Alloc? Free????------ ------ ------ ------ ------ ------ ------ Native Heap 1895618940? 0?4696 44288 21352 22935 Dalvik Heap 60102 60088? 0 26192 104486 88285 16201 App Summary????? Pss(KB)?????? ------??Java Heap: 61640?? Native Heap:18940???? Code:? 3356???Stack:? 428??? Graphics: 16876? Private Other:? 3840???System:? 2031 ...
13、查看單個(gè)應(yīng)用程序的最大內(nèi)存限制
adb shell getprop | grep heapgrowthlimit
得到的結(jié)果為128M: [dalvik.vm.heapgrowthlimit]: [128m]
這就是說Dalvik Heap size的最大值超過了128M览濒,就很可能發(fā)生OOM
14呆盖、獲取單個(gè)應(yīng)用的電量消耗信息
Battery Historian是Android 5.0開始引入的,下面的命令為獲取單個(gè)app的電量消耗信息贷笛,獲取系統(tǒng)耗電信息見下節(jié)
adb shell dumpsys batterystats ><package_name> > xxx.txt
上面的電量信息為原始數(shù)據(jù)应又,可以通過google編寫的historian.py腳本把數(shù)據(jù)信息轉(zhuǎn)換為可讀性很好的html文件,類似TraceView生成的列表數(shù)據(jù),之前在做app性能優(yōu)化的時(shí)候起了很大的作用
python historian.py xxx.txt > xxx.html
15乏苦、跑monkey,個(gè)人很喜歡這個(gè)命令株扛,運(yùn)行過程中,應(yīng)用程序會(huì)不斷切換畫面汇荐,按照選定的不同級(jí)別反饋信息洞就,還可以看到執(zhí)行過程報(bào)告和生成的事件。測(cè)試應(yīng)用的穩(wěn)定性時(shí)很實(shí)用∠铺裕現(xiàn)在studio也有了monkeyrunner的tool
adb shell monkey -v -p <package_name> 500? -p 對(duì)象包? -v 反饋信息級(jí)別
:Monkey: seed=1493061025112 count=500 :AllowPackage:com.tencent.mm.app:push :IncludeCategory: android.intent.category.LAUNCHER:IncludeCategory: android.intent.category.MONKEY ** No activities found to run,monkey aborted.
系統(tǒng)相關(guān)
1旬蟋、查看設(shè)備名稱,豌豆莢等應(yīng)用就是通過此來獲得設(shè)備的名稱
adb shell cat /system/build.prop/
結(jié)果:
ro.product.model=MI 3W ro.product.brand=Xiaomi
2革娄、查看手機(jī)分辨率有兩種方法倾贰,第二種方法最為簡(jiǎn)潔
2.1
adb shell dumpsys window | grep Surface
grep是一個(gè)非常有用的參數(shù),具體含義和用法大家自行g(shù)oogle一下,試驗(yàn)結(jié)果為1080 * 1920:
Surface: shown=false layer=21000 alpha=1.0rect=(0.0,0.0) 1080.0 x 1920.0
2.2.
adb shell wm size
返回結(jié)果為:
Physical size: 1080x1920
3、查看手機(jī)sdk版本
adb shell getprop | grep version
運(yùn)行上面的命令后拦惋,列出來的version中[ro.build.version.release]: [6.0.1]即為手機(jī)sdk版本
4匆浙、查看手機(jī)型號(hào)信息
adb shell getprop | grep product
運(yùn)行此命令之后,能看到product,board,brand和cpu等等的型號(hào)
5厕妖、獲取序列號(hào)首尼,獲取到的序列號(hào)即為adb devices列出來的序列號(hào)
adb get-serialno
6、查看連接的設(shè)備
adb devices
如果有多個(gè)設(shè)備連接,想對(duì)其中的某一設(shè)備進(jìn)行操作饰恕,就需要在此命令的后面加參數(shù)
adb [-d|-e|-s <serial Number>] <command> -d:真機(jī)(多個(gè)設(shè)備中只有一個(gè)真機(jī)時(shí)適用) -e:模擬器(多個(gè)設(shè)備中只有一個(gè)模擬器時(shí)適用) -s:序列號(hào)
假如有兩個(gè)真機(jī)連接了我的電腦挠羔,adb devices獲取到的數(shù)據(jù)如下
List of devices attached 1b71651 device 12sdfsd device
進(jìn)入1b71651設(shè)備的命令為:
adb -s 1b71651 shell
7、查看wifi密碼(需要root權(quán)限)
adb shell cat data/misc/wifi/*.conf
8埋嵌、查看wifi_mac
adb shell cat /sys/class/net/wlan0/address
運(yùn)行此命令破加,93:a1:a2:91:d1:c1是小米3的wifi_mac地址
9、查看后臺(tái)services信息
adb shell service list
運(yùn)行結(jié)果為
Found 126 services: 0 miui.whetstone.net:[miui.whetstone.INetworkService] 1 miui.whetstone.power: [miui.whetstone.power]...
10雹嗦、查看系統(tǒng)當(dāng)前內(nèi)存占用范舀,為綜述
adb shell cat /proc/meminfo
運(yùn)行結(jié)果:
MemTotal:?1893504 kB MemFree:?? 81200 kBBuffers:?? 14828 kB Cached:?? 244152 kB SwapCached:? 15152 kB Active:?? 541680 kB Inactive:?? 575280 kB ...
11、查看各進(jìn)程詳細(xì)內(nèi)存占用和系統(tǒng)的內(nèi)存占用有幾種方法
11.1
adb shell dumpsys meminfo
Total PSS SWAP by process:? 97858 kB: 34944 kB: com.android.systemui (pid2769)? ... Total RAM: 1893504 kB (statusnormal) Free RAM: 344212 kB (117992 cached pss + 136016 cached kernel + 90204free)
Total PSS 信息就是你的應(yīng)用真正占據(jù)的內(nèi)存大小了罪,通過這個(gè)信息锭环,可以輕松判別手機(jī)中哪些程序占內(nèi)存比較大。
11.2 查看各進(jìn)程內(nèi)存的另一方法 不是所有設(shè)備都支持
adb shell procrank
運(yùn)行結(jié)果如下:
PID? Vss? Rss?Pss? Uss cmdline 496 1810184K92744K 57607K 48348K system_server 743 1847492K 84492K 52117K 46796Kcom.android.systemui ....?????? ------------ ------?????? 328259K 261484K TOTALRAM: 2061012K total, 889152K free, 40940K buffers, 612032K cached, 300K shmem,62556K slab
其中
VSS – Virtual Set Size 虛擬耗用內(nèi)存(包含共享庫占用的內(nèi)存) RSS – Resident Set Size 實(shí)際使用物理內(nèi)存(包含共享庫占用的內(nèi)存) PSS – Proportional Set Size 實(shí)際使用的物理內(nèi)存(比例分配共享庫占用的內(nèi)存) USS – Unique Set Size 進(jìn)程獨(dú)自占用的物理內(nèi)存(不包含共享庫占用的內(nèi)存)
11.3 查看設(shè)備上進(jìn)程的cpu和內(nèi)存占用情況
adb shell top
12泊藕、查看系統(tǒng)耗電情況
adb shell dumpsys batterystats > xxx.txt
13辅辩、查看系統(tǒng)設(shè)置的鬧鐘
adb shell dumpsys alarm
14、查看系統(tǒng)的wakelock,不合理的使用wakelock會(huì)導(dǎo)致系統(tǒng)耗電加劇
adb shell dumpsys power
返回結(jié)果:
Wake Locks: size=2 PARTIAL_WAKE_LOCK??? 'AudioMix' (uid=1013, pid=236,ws=WorkSource{10018}) PARTIAL_WAKE_LOCK???'Android.media.MediaPlayer' ON_AFTER_RELEASE (uid=10018, pid=24023,ws=null)
文件操作相關(guān):
1娃圆、拷貝文件/目錄到設(shè)備
adb push <local>...<remote>
2玫锋、從設(shè)備拷貝文件/目錄,-a參數(shù)保留了文件的時(shí)間戳和模式
adb pull [-a] <remote>...<local>
3讼呢、查看設(shè)備log,和studio和eclipse的logcat相同撩鹿,可通過參數(shù)控制輸出的日志
adb logcat? -s 過濾指定參數(shù)log? -v time 保留日志時(shí)間? >> 追加寫? > 覆蓋寫
下面的命令含義為:打印出log信息中的時(shí)間并且包含關(guān)鍵字“Test” 的所有l(wèi)og以覆蓋寫的方式保存到test文件
adb logcat -v time -s Test > test.txt
4、列出目錄下的文件和文件夾悦屏,可選參數(shù)-al可查看文件和文件夾的詳細(xì)信息
adb shell ls [-al]
5节沦、進(jìn)入文件夾
adb shell cd <folder>
6、查看文件
adb shell cat <filename>
7础爬、重命名文件
adb shell rename path/oldfilename path/newfilename
8甫贯、刪除文件/文件夾
adb shell rm path/filename? -r 可選參數(shù)用于刪除文件夾及下面的所有文件 eg:adb shell rm -r <folder>
9、移動(dòng)文件
adb shell mv path/filename newpath/filename
10看蚜、拷貝文件
adb shell cp file newpath/file1
11叫搁、創(chuàng)建目錄
adb shell mkdir path/folder
12、設(shè)置文件最高讀寫權(quán)限
adb shell chmod 777 filename
13失乾、手機(jī)未root 查看data/data/某一app文件信息
筆者的小米3沒有root,但是又想方便地查看data/data/目錄下的一些文件纬乍,直接進(jìn)入data會(huì)提示沒有權(quán)限,查看的方式為進(jìn)入data/data/后,運(yùn)行下面的命令碱茁,就能直接進(jìn)入你應(yīng)用的包下了,可通用cp或者mv拷貝或移動(dòng)到sdcard目錄進(jìn)行其他操作
run-as package_name
數(shù)據(jù)庫相關(guān)
數(shù)據(jù)庫的操作和今天的主題關(guān)系不大,增刪改查操作不再列舉仿贬。但是平時(shí)的開發(fā)過程中只是查看數(shù)據(jù)庫中某個(gè)表或者某個(gè)字段纽竣,也無需每次都pull出來之后再查看,用命令行會(huì)更加方便快捷,進(jìn)入到test.db的目錄后,運(yùn)行如下命令
1蜓氨、操作db
sqlite3 test.db
操作:
通過adb操作手機(jī)UI并不常用聋袋,但在有的場(chǎng)景下會(huì)非常有用,比如測(cè)試自動(dòng)化穴吹,訪問在遠(yuǎn)端服務(wù)器上的手機(jī)等幽勒。