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)先級(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ī)等幽勒。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市港令,隨后出現(xiàn)的幾起案子啥容,更是在濱河造成了極大的恐慌,老刑警劉巖顷霹,帶你破解...
    沈念sama閱讀 216,470評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咪惠,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡淋淀,警方通過查閱死者的電腦和手機(jī)遥昧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來朵纷,“玉大人七兜,你說我怎么就攤上這事≡鹁玻” “怎么了贩汉?”我有些...
    開封第一講書人閱讀 162,577評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)革屠。 經(jīng)常有香客問我凿试,道長(zhǎng),這世上最難降的妖魔是什么似芝? 我笑而不...
    開封第一講書人閱讀 58,176評(píng)論 1 292
  • 正文 為了忘掉前任那婉,我火速辦了婚禮,結(jié)果婚禮上党瓮,老公的妹妹穿的比我還像新娘详炬。我一直安慰自己,他們只是感情好寞奸,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評(píng)論 6 388
  • 文/花漫 我一把揭開白布呛谜。 她就那樣靜靜地躺著,像睡著了一般枪萄。 火紅的嫁衣襯著肌膚如雪隐岛。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評(píng)論 1 299
  • 那天瓷翻,我揣著相機(jī)與錄音聚凹,去河邊找鬼割坠。 笑死,一個(gè)胖子當(dāng)著我的面吹牛妒牙,可吹牛的內(nèi)容都是我干的彼哼。 我是一名探鬼主播,決...
    沈念sama閱讀 40,041評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼湘今,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼敢朱!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起象浑,我...
    開封第一講書人閱讀 38,903評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤蔫饰,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后愉豺,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體篓吁,經(jīng)...
    沈念sama閱讀 45,319評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評(píng)論 2 332
  • 正文 我和宋清朗相戀三年蚪拦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了杖剪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,703評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡驰贷,死狀恐怖盛嘿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情括袒,我是刑警寧澤次兆,帶...
    沈念sama閱讀 35,417評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站锹锰,受9級(jí)特大地震影響芥炭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜恃慧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評(píng)論 3 325
  • 文/蒙蒙 一园蝠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧痢士,春花似錦彪薛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至城侧,卻和暖如春易遣,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赞庶。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評(píng)論 1 269
  • 我被黑心中介騙來泰國打工训挡, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人歧强。 一個(gè)月前我還...
    沈念sama閱讀 47,711評(píng)論 2 368
  • 正文 我出身青樓澜薄,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親摊册。 傳聞我的和親對(duì)象是個(gè)殘疾皇子肤京,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容