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)先級:
V — 細(xì)則 (最低優(yōu)先級)
D — 調(diào)試
I — 信息
W — 警告
E — 錯誤
F — 致命
S — 靜默 (最高優(yōu)先級,不會打印任何信息)
使用grep過濾
這個很像在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、啟動adb服務(wù)
adb start-server
2、終止adb服務(wù)
adb kill-server
3、進(jìn)入adb運行環(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)目錄時很重要
adb remount
8、重啟設(shè)備,可選參數(shù)進(jìn)入bootloader(刷機模式)或recovery(恢復(fù)模式)
adb reboot [bootloader|recovery]
apk相關(guān):
1、安裝apk
adb install test.apk
-r 覆蓋安裝,保留數(shù)據(jù)和緩存文件(adb install -rtest.apk)
-d 解決低版本version問題
-s 安裝apk到sd卡
2、卸載apk
adb uninstall -k
可選參數(shù)-k的作用為卸載軟件但是保留配置和緩存文件
3、查看app相關(guān)所有信息,包括action,codepath,version,需要的權(quán)限等等信息
adb shell dumpsys package
4、查看app的路徑
adb shell pm path
查看了一個普通app的路徑,如下,位于data/app下面的普通app
package:/data/app/com.tencent.test-1/base.apk
5、查看apk的版本信息
adb shell dumpsys package | grepversion
如果你得到的是下圖的兩個version版本,則為系統(tǒng)app,下面是系統(tǒng)app本身的版本,上面是升級之后的系統(tǒng)app的版本信息
versionCode=8 targetSdk=22? versionName=V0.08versionCode=6targetSdk=22? versionName=V0.0
6、啟動activity
查看:
adb shell dumpsys window | findstr mCurrentFocus ?命令查看當(dāng)前運行的包名和Activity
adb shell am start -n /.
C:\Users\lenovo>adb shell
venus:/ $ ^C
C:\Users\lenovo>adb shell dumpsys window | findstrmCurrentFocus
mCurrentFocus=Window{3bd0b18u0com.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
輸出安裝包的APK路徑
adb shell pm clear
刪除與包相關(guān)的所有數(shù)據(jù):清除數(shù)據(jù)和緩存
7、獲得應(yīng)用的啟動時間,可以很方便地獲取應(yīng)用的啟動時間
adb shell am start -W/.
試驗結(jié)果如下:
adb shell am start -Wcom.cc.test/com.painter.test.PainterMainActivityStarting: Intent {act=android.intent.action.MAINcat=[android.intent.category.LAUNCHER]cmp=com.cc.test/com.painter.test.PainterMainActivity} Status: ok Activity:com.cc.test/com.painter.test.PainterMainActivityThisTime: 355 TotalTime: 355WaitTime: 365 Complete
返回的幾個結(jié)果,以WaitTime為準(zhǔn),返回的是從startActivity到應(yīng)用第一幀完全顯示的時間。
8、啟動service,am的-n參數(shù)表示組件,-a參數(shù)表示命令,-a后面的參數(shù)為manifest中定義的service的action
adb shell am startservice -n/.
也可:
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"--estest_string "this is test string"
10、查看某個app的進(jìn)程相關(guān)信息
10.1
adb shell ps
例如
adb shell ps com.ma.app:push USER? PID PPID VSIZE RSSWCHAN?? PC NAME u0_a116 5483 304 1776564 55112sys_epoll_ 00000000 Scom.ma.app:push
小米手機上測試成功,在另外一個設(shè)備上,如果ps后面的參數(shù)是包名則顯示不了進(jìn)程的詳細(xì)信息,參見下面的方式獲取
10.2
adb shell ps | grep
11、殺掉某個進(jìn)程,一般用于模擬某個bug復(fù)現(xiàn)
adb shell kill pid Number
12、查看某一個app的內(nèi)存占用
adb shell dumpsys meminfo
結(jié)果如下,其中的Heap size包括了Dalvik Heap和Native Heap,平時我們所說的內(nèi)存限制指的是Dalvik Heap。
Pss PrivatePrivate Swapped? Heap?Heap?Heap???? Total Dirty CleanDirty? SizeAlloc? Free????------ ------ ------ ------ ------------ ------ Native Heap 1895618940? 0?4696 44288 21352 22935 DalvikHeap 60102 60088? 0 26192 104486 88285 16201 AppSummary?????Pss(KB)?????? ------??Java Heap:61640?? Native Heap:18940???? Code:?3356???Stack:? 428??? Graphics: 16876?Private Other:? 3840???System:? 2031 ...
13、查看單個應(yīng)用程序的最大內(nèi)存限制
adb shell getprop | grep heapgrowthlimit
得到的結(jié)果為128M: [dalvik.vm.heapgrowthlimit]: [128m]
這就是說Dalvik Heap size的最大值超過了128M,就很可能發(fā)生OOM
14、獲取單個應(yīng)用的電量消耗信息
Battery Historian是Android 5.0開始引入的,下面的命令為獲取單個app的電量消耗信息,獲取系統(tǒng)耗電信息見下節(jié)
adb shell dumpsys batterystats > > xxx.txt
上面的電量信息為原始數(shù)據(jù),可以通過google編寫的historian.py腳本把數(shù)據(jù)信息轉(zhuǎn)換為可讀性很好的html文件,類似TraceView生成的列表數(shù)據(jù),之前在做app性能優(yōu)化的時候起了很大的作用
python historian.py xxx.txt > xxx.html
15、跑monkey,個人很喜歡這個命令,運行過程中,應(yīng)用程序會不斷切換畫面,按照選定的不同級別反饋信息,還可以看到執(zhí)行過程報告和生成的事件。測試應(yīng)用的穩(wěn)定性時很實用?,F(xiàn)在studio也有了monkeyrunner的tool
adb shell monkey -v -p <package_name> 500? -p 對象包? -v 反饋信息級別
: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、查看手機分辨率有兩種方法,第二種方法最為簡潔
2.1
adb shell dumpsys window | grep Surface
grep是一個非常有用的參數(shù),具體含義和用法大家自行g(shù)oogle一下,試驗結(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、查看手機sdk版本
adb shell getprop | grep version
運行上面的命令后,列出來的version中[ro.build.version.release]: [6.0.1]即為手機sdk版本
4、查看手機型號信息
adb shell getprop | grep product
運行此命令之后,能看到product,board,brand和cpu等等的型號
5、獲取序列號,獲取到的序列號即為adb devices列出來的序列號
adb get-serialno
6、查看連接的設(shè)備
adb devices
如果有多個設(shè)備連接,想對其中的某一設(shè)備進(jìn)行操作,就需要在此命令的后面加參數(shù)
adb [-d|-e|-s <serial Number>] <command>? -d:真機(多個設(shè)備中只有一個真機時適用)? -e:模擬器(多個設(shè)備中只有一個模擬器時適用)? -s:序列號
假如有兩個真機連接了我的電腦,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
運行此命令,93:a1:a2:91:d1:c1是小米3的wifi_mac地址
9、查看后臺services信息
adb shell service list
運行結(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
運行結(jié)果:
MemTotal:?1893504 kB MemFree:?? 81200kBBuffers:?? 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)存大小,通過這個信息,可以輕松判別手機中哪些程序占內(nèi)存比較大。
11.2 查看各進(jìn)程內(nèi)存的另一方法 不是所有設(shè)備都支持
adb shell procrank
運行結(jié)果如下:
PID? Vss? Rss?Pss? Uss cmdline 496 1810184K92744K57607K 48348K system_server 743 1847492K 84492K 52117K46796Kcom.android.systemui ....??????------------ ------?????? 328259K 261484KTOTALRAM: 2061012K total, 889152K free, 40940K buffers, 612032K cached, 300Kshmem,62556K slab
其中
VSS – Virtual Set Size 虛擬耗用內(nèi)存(包含共享庫占用的內(nèi)存) RSS – Resident Set Size 實際使用物理內(nèi)存(包含共享庫占用的內(nèi)存) PSS – Proportional Set Size 實際使用的物理內(nèi)存(比例分配共享庫占用的內(nèi)存) USS – Unique Set Size 進(jìn)程獨自占用的物理內(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會導(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 ...
2、從設(shè)備拷貝文件/目錄,-a參數(shù)保留了文件的時間戳和模式
adb pull [-a] ...
3、查看設(shè)備log,和studio和eclipse的logcat相同,可通過參數(shù)控制輸出的日志
adb logcat? -s 過濾指定參數(shù)log?
-v time 保留日志時間? >> 追加寫? > 覆蓋寫
下面的命令含義為:打印出log信息中的時間并且包含關(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
6、查看文件
adb shell cat
7、重命名文件
adb shell rename path/oldfilename path/newfilename
8、刪除文件/文件夾
adb shell rm path/filename? -r 可選參數(shù)用于刪除文件夾及下面的所有文件eg:adb shell rm -r
9、移動文件
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、手機未root 查看data/data/某一app文件信息
筆者的小米3沒有root,但是又想方便地查看data/data/目錄下的一些文件,直接進(jìn)入data會提示沒有權(quán)限,查看的方式為進(jìn)入data/data/后,運行下面的命令,就能直接進(jìn)入你應(yīng)用的包下了,可通用cp或者mv拷貝或移動到sdcard目錄進(jìn)行其他操作
run-as package_name
數(shù)據(jù)庫相關(guān)
數(shù)據(jù)庫的操作和今天的主題關(guān)系不大,增刪改查操作不再列舉。但是平時的開發(fā)過程中只是查看數(shù)據(jù)庫中某個表或者某個字段,也無需每次都pull出來之后再查看,用命令行會更加方便快捷,進(jìn)入到test.db的目錄后,運行如下命令
1、操作db
sqlite3 test.db
操作:
通過adb操作手機UI并不常用,但在有的場景下會非常有用,比如測試自動化,訪問在遠(yuǎn)端服務(wù)器上的手機等。