在SDK的Tools檔案夾下包含著Android模擬器操作的重要命令ADB,ADB的全稱為Android Debug Bridge,就是調試橋的作用,藉助這個工具,我們可以管理裝置或手機模擬器的狀態 ,還可以進行以下的操作:
(1)快速更新裝置或手機模擬器中的代碼,如應用或Android系統升級;
(2)在裝置上運行Shell命令;
(3)管理裝置或手機模擬器上的預定連接埠;
(4)在裝置或手機模擬器上複製或粘貼檔案。
ADB的工作方式比較特殊採用監聽Socket TCP 5554等連接埠的方式讓IDE和Qemu通訊,預設情況下ADB會daemon相關的網路連接埠,所以當我們運行Eclipse時ADB進程就會自動運行,在Eclipse中通過DDMS來調試Android程式;也可以通過手動方式調用,以下為一些常用的操作供參考。
1.版本資訊
D:\unsetup\android-sdk-windows-1.0_r1\tools>adb version
Android Debug Bridge version 1.0.20
2.安裝應用到模擬器
adb install [-l] [-r] <file>。
其中file是需要安裝的apk檔案的決定路徑。
3.卸載已經安裝的應用
(1)方法1:
adb uninstall [-k] <package>。
其中package表示需要卸載的應用的包的名字,k表示是否保留應用的配置資訊和cache資料。
(2)手動刪除。
adb shell
cd /data/app
rm app.apk
4.進入裝置或模擬器的Shell
adb shell
通過上面的命令,就可以進入裝置或模擬器的Shell環境中,在這個Linux Shell中,可以執行各種Linux 的命令,另外如果只想執行一條Shell命令,可以採用以下的方式:
adb shell [command]
如:
D:\unsetup\android-sdk-windows-1.0_r1\tools>adb shell df
/dev: 49564K total, 0K used, 49564K available (block size 4096)
/sqlite_stmt_journals: 4096K total, 0K used, 4096K available (block size 4096)
/system: 69120K total, 65508K used, 3612K available (block size 4096)
/data: 76544K total, 63684K used, 12860K available (block size 4096)
/cache: 69120K total, 1244K used, 67876K available (block size 4096)
5.轉送連接埠
可以使用 forward 命令進行任意連接埠的轉寄—一個模擬器/裝置執行個體的某一特定主機連接埠向另一不同連接埠的轉寄請求。下面示範了如何建立從主機連接埠7100到模擬器/裝置連接埠8100的轉寄。
adb forward tcp:7100 tcp:8100
同樣地,可以使用ADB來建立命名為抽象的UNIX域套介面,上述過程如下所示:
adb forward tcp:7100 local:logd
6.複製檔案
可以使用adb pull ,push 命令將檔案複製到一個模擬器/裝置執行個體的資料檔案或是從資料檔案中複製。install 命令只將一個apk檔案複製到一個特定的位置,與其不同的是,pull 和 push 命令可讓使用者複製任意的目錄和檔案到一個模擬器/裝置執行個體的任何位置。
從模擬器或者裝置中複製檔案或目錄,使用如下命:
adb pull <remote> <local>
將檔案或目錄複寫到模擬器或者裝置,使用如下命令:
adb push <local> <remote>
在這些命令中, <local> 和<remote> 分別指通向自己的發展機(本地)和模擬器/裝置執行個體(遠程)上的目標檔案/目錄的路徑。
下面是一個例子::
adb push foo.txt /sdcard/foo.txt
7.搜尋模擬器/裝置的執行個體
取得當前啟動並執行模擬器/裝置的執行個體的列表及每個執行個體的狀態,如:
D:\unsetup\android-sdk-windows-1.0_r1\tools>adb devices
List of devices attached
HT843GZ03305 device
8.查看bug報告
D:\unsetup\android-sdk-windows-1.0_r1\tools>adb bugreport
========================================================
== dumpstate
========================================================
------ SYSTEM LOG ------
04-12 16:59:46.521 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.
04-12 16:59:46.531 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.
04-12 16:59:46.531 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.
04-12 16:59:46.541 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.
04-12 16:59:47.391 I/ActivityManager( 55): Starting activity: Intent { comp={com.iceskysl.iTracks/com.iceskysl.iTracks.iTracks} }
04-12 16:59:47.641 D/iTracks (23968): renderListView.
04-12 16:59:47.671 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.
04-12 16:59:47.681 D/ShowTrack(23968): MyOverlay::darw..mDefCaption=I'm Here.
9.記錄無線通訊日誌
一般來說,無線通訊的日誌非常多,在運行時沒必要去記錄,但我們還是可以通過命令,設定記錄:
D:\unsetup\android-sdk-windows-1.0_r1\tools>adb shell
# logcat -b radio
logcat -b radio
D/HTC_RIL ( 30): (t=1239390296)<< 0
D/HTC_RIL ( 30): (t=1239390296)>> AT@HTCPDPFD=0
D/HTC_RIL ( 30): (t=1239390296)<< 0
D/HTC_RIL ( 30): (t=1239390296)>> AT+CSQ
D/HTC_RIL ( 30): (t=1239390296)<< +CSQ: 29,99
D/HTC_RIL ( 30): 0
D/HTC_RIL ( 30): (t=1239390296)>> AT+CREG?
D/HTC_RIL ( 30): (t=1239390296)<< +CREG: 2,3
D/HTC_RIL ( 30): 0
10.擷取裝置的ID和序號
adb get-product
D:\unsetup\android-sdk-windows-1.0_r1\tools>adb get-serialno
HT843GZ03305
11.通過遠程Shell端運行AQLite3串連資料庫
通過ADB遠程Shell端,可以通過Android的軟AQLite 3 命令程式來管理資料庫。SQLite 3 工具包含了許多使用命令,例如,.dump 顯示表的內容,.schema 可以顯示出已經存在的資料表空間的SQL CREATE結果集。SQLite3還允許遠程執行sql命令。
通過SQLite 3 , 按照前面的方法登入模擬器的遠程Shell端,然後啟動工具就可以使用SQLite 3 命令。當SQLite 3 啟動以後,還可以指定想查看的資料庫的完整路徑。模擬器/裝置執行個體會在檔案夾中儲存SQLite3資料庫/data/data/<package_name> /databases /。
樣本如下:
$ adb shell
# sqlite3 /data/data/com.example.google.rss.rssexample/databases/rssitems.db
SQLite version 3.3.12
Enter ".help" for instructions
.... enter commands, then quit...
sqlite> .exit
當啟動SQLite 3的時候,就可以通過Shell端發送SQLite 3,命令了。用exit 或<Ctrl+D>按鍵組合退出ADB遠程Shell端。
12.ADB命令列表
下列表格列出了adb支援的所有命令,並對它們的意義和使用方法做了說明.
Category |
Command |
Description |
Comments |
Options |
-d |
僅僅通過USB介面來管理abd |
如果不只是用USB介面來管理則返回錯誤 |
-e |
僅僅通過模擬器執行個體來管理adb |
如果不是僅僅通過模擬器執行個體管理則返回錯誤 |
-s <serialNumber> |
通過模擬器/裝置的允許命令號碼來發送命令來管理adb (如 “emulator-5556″) |
如果沒有指定號碼,則會報錯 |
General |
devices |
查看所有串連模擬器/裝置的設施的清單 |
查看 Querying for Emulator/Device Instances 擷取更多相關資訊 |
help |
查看adb所支援的所有命令 |
|
version |
查看adb的版本序號 |
|
Debug |
logcat [<option>] [<filter-specs>] |
將日誌資料輸出到螢幕上 |
|
bugreport |
查看bug的報告,如dumpsys ,dumpstate ,和logcat 資訊 |
|
jdwp |
查看指定設施的可用的JDWP資訊 |
可以用 forward jdwp:<pid>連接埠映射資訊來串連指定的JDWP進程,例如: adb forward tcp:8000 jdwp:472 jdb -attach localhost:8000 |
Data |
install <path-to-apk> |
安裝Android為(可以模擬器/設施的資料檔案.apk指定完整的路徑) |
|
pull <remote> <local> |
將指定的檔案從模擬器/設施拷貝到電腦上 |
|
push <local> <remote> |
將指定的檔案從電腦上拷貝到模擬器/裝置中 |
|
Ports and Networking |
forward <local> <remote> |
用本地指定的連接埠通過Socket方法遠端連線模擬器/設施 |
連接埠需要描述下列資訊:
- tcp:<portnum>
- local:<UNIX domain socket name>
- dev:<character device name>
- jdwp:<pid>
|
ppp <tty> [parm]… |
通過USB運行ppp:
- <tty> — the tty for PPP stream. For exampledev:/dev/omap_csmi_ttyl.
- [parm]… &mdash zero or more PPP/PPPD options, such as defaultroute ,local , notty , etc.
需要提醒的不能自動啟動PDP串連 |
|
Scripting |
get-serialno |
查看adb執行個體的序號 |
查看 Querying for Emulator/Device Instances 可以獲得更多資訊 |
get-state |
查看模擬器/設施的目前狀態 |
wait-for-device |
如果裝置不聯機就不讓執行,也就是執行個體狀態是 device 時 |
可以提前把命令轉載在adb的命令器中,在命令器中的命令在模擬器/裝置串連之前是不會執行其他命令的,樣本如下: adb wait-for-device shell getprop 需要提醒的是,這些命令在所有的系統啟動起來之前是不會啟動adb的,所以在所有的系統啟動起來之前也不能執行其他的命令,例如,運用install 的時候就需要Android包,這些包需要系統完全啟動,例如: adb wait-for-device install <app>.apk 上面的命令只有串連上了模擬器/裝置串連上了adb服務才會被執行,而在Android系統完全啟動前執行就會有錯誤發生 |
Server |
start-server |
選擇服務是否啟動adb服務進程 |
|
kill-server |
終止adb服務進程 |
|
Shell |
shell |
通過遠程Shell命令來控制模擬器/裝置執行個體 |
查看擷取更多資訊 for more information |
shell [<shellCommand>] |
串連模擬器/設施執行Shell命令,執行完畢後退出遠程Shell端l |