這是摘錄androidin.com的一篇文章,對於學習Android的朋友來說,可以做工具來參考下。
http://wuhua.iteye.com/category/26760
(hanchao3c Android 開發人員論壇原創,轉載請註明)
logcat是Android中一個命令列工具,可以用於得到程式的log資訊。
logcat使用方法如下所示:
logcat [options] [filterspecs]
logcat的選項包括:
-s 設定過濾器,例如指定 '*:s'
-f <filename> 輸出到檔案,預設情況是標準輸出。
-r [<kbytes>] Rotate log every kbytes. (16 if unspecified). Requires -f
-n <count> Sets max number of rotated logs to <count>, default 4
-v <format> 設定log的列印格式, <format> 是下面的一種:
brief process tag thread raw time threadtime long
-c 清除所有log並退出
-d 得到所有log並退出 (不阻塞)
-g 得到環形緩衝區的大小並退出
-b <buffer> 請求不同的環形緩衝區 ('main' (預設), 'radio', 'events')
-B 輸出log到二進位中。
過濾器的格式是一個這樣的串:
<tag>[:priority]
其中 <tag> 表示log的component, tag (或者使用 * 表示所有) , priority 如下所示:
V Verbose
D Debug
I Info
W Warn
E Error
F Fatal
S Silent
事實上logcat的功能 是由Android的類android.util.Log決定的,在程式中log的使用方法如下所示:
Log.v() -------------------- VERBOSE
Log.d() -------------------- DEBUG
Log.i() -------------------- INFO
Log.w() -------------------- WARN
Log.e() -------------------- ERROR
以上log的層級依次升高,DEBUG資訊應當只存在於開發中,INFO, WARN,ERROR這三種log將出現在發布版本中。
對於JAVA類,可以聲明一個字串常量TAG,Logcat可以根據他來區分不同的log,例如在計算機(Calculator)的類中,定義如下所示:
public class Calculator extends Activity {
/* ...... */
private static final String LOG_TAG = "Calculator";
private static final boolean DEBUG = false;
private static final boolean LOG_ENABLED = DEBUG ? Config.LOGD : Config.LOGV;
/* ...... */
由此,所有在Calculator中使用的log,均以"Calculator"為開頭。
例如使用方法如下所示:
# logcat &
< 得到一個log片段 >
W/KeyCharacterMap( 130): No keyboard for id 0
W/KeyCharacterMap( 130): Using default keymap: /system/usr/keychars/qwerty.kcm.bin
I/ActivityManager( 52): Displayed activity com.android.contacts/.DialtactsContactsEntryActivity: 983 ms
I/ARMAsse mbler( 52): generated scanline__00000077:03545404_00000A04_00000000 [ 29 ipp] (51 ins) at [0x25c978:0x25ca44] in 1764174 ns
I/ARMAssembler( 52): generated scanline__00000077:03515104_00000001_00000000 [ 46 ipp] (65 ins) at [0x25d1c8:0x25d2cc] in 776789 ns
D / dalvikvm ( 130 ):
GC freed 834 objects / 81760 bytes in 63ms
D/dalvikvm( 52): GC freed 10588 objects / 425776 bytes in 94ms
其中W/I/D 表示log的層級,“dalvikvm ”“ARMAssembler ”等是不同組件(component)的名稱,後面括弧裡面的數字 表示了發出log的進程號。
提示:
1.使用logcat &在後台運行
2.使用-d得到所有log
3.使用-f或者重新導向(>和>>)輸出到檔案
4.使用-s設定過濾器,得到想要的log。
當然,最重要的還是在程式中加入恰當的log.
許多初次接觸Android開發的朋友會遇到調試的問題,如何能夠根據錯誤提示迅速的找到“出事地點呢”?在Eclipse+ADT的開發環境中沒 有好的直接跟蹤對象內容的方法,通過使用android.util.Log類可以協助你自己尋找錯誤和列印系統日誌訊息。它是一個進行日誌輸出的API, 我們在Android 程式中可以隨時為某一個對象插入一個Log,然後在DDMS中觀察Logcat的輸出是否正常。
android.util.Log常用的方法有以下5個:Log.v() Log.d() Log.i() Log.w() 以及 Log.e() 。根據首字母對應VERBOSE,DEBUG,INFO, WARN,ERROR。當我們在DDMS進行調試時他們的區別並不大,只是顯示的顏色不同,但通過Logcat的過濾器我們可以過濾顯示某類的,一般對於 執行錯誤的斷點,下在Log.e比較合適。但是Android開發網根據規範建議VERBOSE,DEBUG資訊應當只存在於開發中,最終版本只可以包含 INFO, WARN,ERROR這三種日誌資訊。在實際使用中,我們最好為每一個類聲明一個字串常量TAG,這樣在Logcat中我們可以容易
區分不同的類的日誌。例如:
private static final String TAG = "MyActivity";
接下來我們就可以用Log隨心所欲的觀察Android代碼中的每個細節:Log.e(TAG, "android123.com.cn"); 但是要記住這個Log類的參數都是String類型的。下面是DDMS中的Logcat:
最後介紹一下Android的Log工具LogCat。
首先在Eclipse中選擇Windows > Show View > Other... > Android > LogCat,確定後會出現LogCat顯示框,使用者添加的Log將會在這裡顯示。 使用時直接在代碼中插入“Log.i("info","this is a log");”,那麼在執行到該語句時,LogCat顯示框中將出現“this is a log”。詳細的用法請參考Android文檔。