logcat是啥意思
log cat
日志貓
log
[英][lɒg][美][lɔ:g]
n.日志; 記錄; 原木;
v.伐木; 把…載入正式記錄; 行駛
例句
1 The records must be successfully written to the queue manager log for the application to correctly commit its updates.
這些記錄必須成功寫入到隊列管理器日志,以便應用程序能夠正確地提交其更新。
2 Imagine the hours urs may log uploading photos and labeling events from the lost decades B.F. ( before Facebook).
我們不妨設想一下,假如用戶要補上個人在Facebook誕生之前數十年間的生活片段,他們將要花多少時間上傳照片,整理活動記錄。
3 The original log cabin where Lincoln was born
林肯誕生的原來那座原木小屋
logcat是什么
logcat是Android中一個命令行工具,可以用于得到程序的log信息。
logcat使用方法如下所示[1]:
[adb] logcat [<option>] ... [<filter-spec>] ...
[options]命令包括如下選項:
-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 清除所有l(wèi)og并退出
-d 得到所有l(wèi)og并退出 (不阻塞)
-g 得到環(huán)形緩沖區(qū)的大小并退出
-b <buffer> 請求不同的環(huán)形緩沖區(qū) ('main', 'system', 'radio', 'events',默認為"-b main -b system")
-B 輸出log到二進制中。
過濾器的格式是一個這樣的串:
<tag>[:priority]
其中 <tag> 表示log的component, tag (或者使用 * 表示所有) , priority 從低到高如下所示:
V Verbo
D Debug
I Info
W Warn
E Error
F Fatal
S Silent
華為手機logcat怎么打開
華為手機默認是關閉logcat信息的,這在開發(fā)調試時當然很不方便,打開log信息的方法如下:
進入撥號界面輸入:*#*#2846579#*#*;
依次選擇ProjectMenu---后臺設置----LOG設置---LOG開關 點擊打開, 然后在LOG級別選VERBOSE;
重新啟動手機即可。
手機logcat怎么用
您好,很高興為您解答。
1,安裝SDK(參考android sdk環(huán)境安裝)
2,使用數據線鏈接手機,在手機助手的sdcard中建立一個1.log的文件
3,程序運行cmd
4,輸入抓取命令:logcat -s '*:E' > /mmt/sdcard/1.log
5,使用手機崩潰一次
6,查看日志抓取文件,分不清楚是那個時間段所造成的后果
7,加入命令:-v time 就會顯示出時間
8,輸入命令logcat -v time -s '*:E' > /mmt/sdcard/1.log
9,查看結果
在Android開發(fā)中,Logcat是什么?
最后介紹一下Android的Log工具LogCat。
首先在Eclip中選擇Windows > Show View > Other... > Android > LogCat,確定后會出現LogCat顯示框,用戶添加的Log將會在這里顯示。使用時直接在代碼中插入“Log.i("info","this is a log");”,那么在執(zhí)行到該語句時,LogCat顯示框中將出現“this is a log”。
在Eclip中安裝ADT和android sdk包之后,運行以開發(fā)的android程序時,在LogCat窗口中會顯示出一系列的信息,這些信息是每一個程序通過Dalvik虛擬機所傳出的實時信息,可以方便我們對程序的了解。
在log窗口中,每條信息都包含五個部分,Time,標題空白,pid,tag和Message。
1、Time
表示執(zhí)行的時間,這個信息對于學習生命周期,分析程序運行的先后順序特別有用。
2、標題空白的列
表示的是信息的種類,分為V,D,I,W,E五種。
V:verbo,顯示全部信息
D:Debug,顯示調試信息
I:Info,顯示一般信息
W:Warming,顯示警告信息
E:Error,顯示錯誤信息
可以通過點擊LogCat上面的用圓圈括起來的V,D,I,W,E來改變顯示的范圍。比如選擇了W,那就只有警告信息和錯誤信息可以顯示出來了。
3、pid
表示程序運行時的進程號
4、tag
標簽,通常表示系統(tǒng)中的一些進程名,比如我們運行helloworld程序的話,就會看到activitymanager在運行。
5、Message
表示進程運行時的一些具體信息,比如我們運行helloworld程序的話,就會看到starting activity...helloWorld的字樣
可以輸出LogCat的信息到文本文件中,以方便分析。在下拉框中選擇輸出選擇的信息就可以了。
下面是輸出到文件中的啟動helloWorld程序時的一條信息的例子,分別用5個下劃線標出了上面介紹的內容:
05-20 15:46:10.129: INFO/ActivityManager(60): Starting activity: Intent { act=android.intent.action.MAIN cat=
[android.intent.category.LAUNCHER] flg=0x10200000 cmp=com.example.android.helloworld/.HelloWorld }
6、Filter的使用
可以在Filter中輸入篩選信息,使LogCat中只現實我們需要分析的信息。比如我們只想看和HelloWorld相關的信息,就可以在
Filter中輸入HelloWorld,這樣只有Message 中包含HelloWorld的內容才會顯示出來。
7、LogCat中信息不能顯示
上面說了這么多關于logCat的使用,可能LogCat中根本就什么信息都沒有顯示!沒關系,只要在Eclip中選擇window-
>show view->other->android->devices就可以 了。
8、在LogCat中輸出程序的運行信息
a、在程序中導入相應的包:import android.util.Log;
b、在需要輸出信息的函數中增加相關的調試代碼:Log.i("hi world","oncreate");
方法i是Log類的靜態(tài)方法,可以直接使用,我們看著各類的定義可以看到,它提供了多種輸出方法,分別對應我們上面提到的V,D,I,W,E。用哪個方法就決定了輸出的類型,這里用i,表示輸出的是information。
這個方法中的第一個參數就是要顯示在Tag那一欄的內容,把這條語句加到OnCreate方法中,執(zhí)行時LogCat中就會顯示如下的信息: 05-22 21:58:22.894 I 3910 hi world onCreate
9、創(chuàng)建新的Filter
有時候只想看我們程序中用Log類的相關方法輸出的各種信息,這時就可以考慮新建一個過濾器。點擊LogCat的右上角的“+”號,可以創(chuàng)建一個新的過濾器。比如我們在by Log Tag的選項中填入上面程序輸出的"hi world"這個tag。這樣再運行時在我們新創(chuàng)建的Filter中就只顯示hi world這個tag標記出來的信息了。
Android開發(fā)中的logcat工具使用詳解--------
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 清除所有l(wèi)og并退出
-d 得到所有l(wèi)og并退出 (不阻塞)
-g 得到環(huán)形緩沖區(qū)的大小并退出
-b <buffer> 請求不同的環(huán)形緩沖區(qū) ('main' (默認), 'radio', 'events')
-B 輸出log到二進制中。
過濾器的格式是一個這樣的串:
<tag>[:priority]
其中 <tag> 表示log的component, tag (或者使用 * 表示所有) , priority 如下所示:
V Verbo
D Debug
I Info
W Warn
E Error
F Fatal
S Silent
事實上logcat的功能 是由Android的類android.util.Log決定的,在程序中l(wèi)og的使用方法如下所示:
Log.v() -------------------- VERBOSE
Log.d() -------------------- DEBUG
Log.i() -------------------- INFO
Log.w() -------------------- WARN
Log.e() -------------------- ERROR
以上log的級別依次升高,DEBUG信息應當只存在于開發(fā)中,INFO, WARN,ERROR這三種log將出現在發(fā)布版本中。
對于JAVA類,可以聲明一個字符串常量TAG,Logcat可以根據他來區(qū)分不同的log,例如在計算器(Calculator)的類中,定義如下所示:
public class Calculator extends Activity {
/* ...... */
private static final String LOG_TAG = "Calculator";
private static final boolean DEBUG = fal;
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/ARMAs mbler( 52): generated scanline__00000077:03545404_00000A04_00000000 [ 29 ipp] (51 ins) at [0x25c978:0x25ca44] in 1764174 ns
I/ARMAsmbler( 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 ”“ARMAsmbler ”等是不同組件(component)的名稱,后面括號里面的數字 表示了發(fā)出log的進程號。
使用技巧:
1.使用logcat &在后臺運行
2.使用-d得到所有l(wèi)og
3.使用-f或者重定向(>和>>)輸出到文件
4.使用-s設置過濾器,得到想要的log。
當然,最重要的還是在程序中加入恰當的log.
許多初次接觸Android開發(fā)的朋友會遇到調試的問題,如何能夠根據錯誤提示迅速的找到“出事地點呢”?在Eclip+ADT的開發(fā)環(huán)境中沒有好的直接跟蹤對象內容的方法,通過使用android.util.Log類可以幫助你自己查找錯誤和打印系統(tǒng)日志消息。它是一個進行日志輸出的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進行調試時他們的區(qū)別并不大,只是顯示的顏色不同,但通過Logcat的過濾器我們可以過濾顯示某類的,一般對于執(zhí)行錯誤的斷點,下在Log.e比較合適。但是Android開發(fā)網根據規(guī)范建議VERBOSE,DEBUG信息應當只存在于開發(fā)中,最終版本只可以包含 INFO, WARN,ERROR這三種日志信息。在實際使用中,我們最好為每一個類聲明一個字符串常量TAG,這樣在Logcat中我們可以容易區(qū)分不同的類的日志。例如:
private static final String TAG = "MyActivity";
接下來我們就可以用Log隨心所欲的觀察Android代碼中的每個細節(jié):Log.e(TAG, "android123.com.cn"); 但是要記住這個Log類的參數都是String類型的。
Android 日志系統(tǒng)分析(三):logcat
logcat 作為讀取日志的工具,相當于client 的角色;在前兩篇文章中,關于 logcat 如何與其他部分溝通獲取日志信息的流程已經介紹的比較清晰,本文不在贅述,轉而歸納一下 logcat 的一些常用指令,并對其中一些做詳細分析
Android 日志系統(tǒng)為日志消息保留了多個環(huán)形緩沖區(qū),但并非多有的日志消息都會發(fā)送到默認的環(huán)形緩沖區(qū)。這里可以采用 logcat -b 命令查看設備的其他緩沖區(qū):
如果需要查看內核空間日志信息,可采用如下幾種方式查看:
1、讀取 /proc/kmsg ,命令如下
讀取/proc/kmsg屬于消費型讀取,讀取之后再次讀取不會顯示已經讀取過的日志信息
2、讀取 /dev/kmsg ,命令如下
讀取/dev/kmsg會顯示緩存區(qū)里面的所有日志信息。新寫入的日志信息會不斷累加到日志緩沖器中
3、使用 dmesg 命令讀取
dmesg命令讀取一次只顯示一部分日志,非阻塞執(zhí)行
使用 -v 命令來修改 log 的輸出格式,以顯示特定的元數據字段:
優(yōu)先級:
logcat -f 命令可以將日志消息輸出到指定的文件中。這里我們需要確定的一件事是 logcat 作為客戶端的角色,會將通過 liblog 獲得的日志信息進行格式解析、格式化處理,而 liblog 庫本身并不存在保存、解析的功能。這里來對 -f 指令做一下解析:
在 _logcat() 函數中解析 -f 指令,設置日志輸出文件。例如 logcat -f sdcard/log.txt ,則 context->outputFileName 賦值為 sdcard/log.txt ;
以 printBinary() 函數為例:
logcat.cpp # printBinary() :
[ 1 ] Android物語:logcat
[ 2 ] android調試——logcat詳解
[ 3 ] 玩轉Android10源碼開發(fā)定制(12)內核篇之logcat輸出內核日志