Android開發中的logcat工具使用

來源:互聯網
上載者:User

這是摘錄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文檔。
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.