ADB命令整合

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ù)器上的手機等。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1、日志相關(guān): adb logcat //顯示全部日志 adb logcat > c:\test.log //...
    學(xué)習(xí)不斷閱讀 59,728評論 0 11
  • 原文鏈接:www.itdecent.cn 1、查看最上層成activity名字: adb shell dumps...
    SmileToLin閱讀 977評論 0 1
  • 1、查看最上層成activity名字:adb shell dumpsys activity | findstr "...
    waiwaaa閱讀 1,435評論 0 0
  • 原:http://www.itdecent.cn/p/980fea2c9457 1、查看最上層成activity...
    柒黍閱讀 1,722評論 0 0
  • 1. adb devices 主要作用:查看當(dāng)前已連接的設(shè)備,連接到計算機的Android設(shè)備或者模擬器將...
    C1R2閱讀 1,744評論 0 1

友情鏈接更多精彩內(nèi)容