Android系統(tǒng)開發(fā)中l(wèi)og的使用方法及簡單的原理
更新時間:2013年01月28日 11:01:26 作者:
LOG是廣泛使用的用來記錄程序執(zhí)行過程的機(jī)制,它既可以用于程序調(diào)試,也可以用于產(chǎn)品運(yùn)營中的事件記錄;在平時開發(fā)過程中經(jīng)常需要與log打交道,所以很有必要了解log的使用方法及簡單的原理,感興趣的朋友可以了解下啊
在程序開發(fā)過程中,LOG是廣泛使用的用來記錄程序執(zhí)行過程的機(jī)制,它既可以用于程序調(diào)試,也可以用于產(chǎn)品運(yùn)營中的事件記錄。在Android系統(tǒng)中,提供了簡單、便利的LOG機(jī)制,開發(fā)人員可以方便地使用。在平時開發(fā)過程中經(jīng)常需要與log打交道,所以很有必要了解log的使用方法及簡單的原理。
1、linux內(nèi)核的log輸出
在標(biāo)準(zhǔn)的linux內(nèi)核開發(fā)過程中,使用printk,這是一個與printf輸出打印齊名的函數(shù),同樣提供格式化輸出功能,只是其有
打印級別且將信息保存到/proc/kmsg日志中,使用cat命令查看其信息[cat/proc/kmsg]
<SPANstyle="COLOR:#003333;FONT-SIZE:14px">#defineKERN_EMERG"<0>"/*systemisunusable*/
#defineKERN_ALERT"<1>"/*actionmustbetakenimmediately*/
#defineKERN_CRIT"<2>"/*criticalconditions*/
#deinfeKERN_ERR"<3>"/*errorconditions*/
#deinfeKERN_WARNING"<4>"/*warningconditions*/
#deinfeKERN_NOTICE"<5>"/*normalbutsignificantcondition*/
#deinfeKERN_INFO"<6>"/*informational*/
#deinfeKERN_DEBUG"<7>"/*debug-levelmessages*/</SPAN>
2、android中l(wèi)og輸出
Android系統(tǒng)在用戶空間中提供了輕量級的logger日志系統(tǒng),它是在內(nèi)核中實(shí)現(xiàn)的一種設(shè)備驅(qū)動,與用戶空間的logcat工具配合使用能夠方便地跟蹤調(diào)試程序。
Android系統(tǒng)中的C/C++日志接口是通過宏來使用的。在system/core/include/android/log.h定義了日志的級別:
/*
*Androidlogpriorityvalues,inascendingpriorityorder.
*/
typedefenumandroid_LogPriority{
ANDROID_LOG_UNKNOWN=0,
ANDROID_LOG_DEFAULT,/*onlyforSetMinPriority()*/
ANDROID_LOG_VERBOSE,
ANDROID_LOG_DEBUG,
ANDROID_LOG_INFO,
ANDROID_LOG_WARN,
ANDROID_LOG_ERROR,
ANDROID_LOG_FATAL,
ANDROID_LOG_SILENT,/*onlyforSetMinPriority();mustbelast*/
}android_LogPriority;
為了使用方便,在system/core/include/cutils/log.h定義了相對應(yīng)的宏:
#defineLOGV(...)((void)LOG(LOG_VERBOSE,LOG_TAG,__VA_ARGS__))
#defineLOGD(...)((void)LOG(LOG_DEBUG,LOG_TAG,__VA_ARGS__))
#defineLOGI(...)((void)LOG(LOG_INFO,LOG_TAG,__VA_ARGS__))
#defineLOGW(...)((void)LOG(LOG_WARN,LOG_TAG,__VA_ARGS__))
#defineLOGE(...)((void)LOG(LOG_ERROR,LOG_TAG,__VA_ARGS__))
因?yàn)槿绻枰褂胠og輸出,包含其頭文件:#include<cutils/log.h>并link其動態(tài)庫:liblog.so即可
#defineLOG_TAG"XX_LOG_TAG"http://這里可以定義其輸出的TAG
#include<cutils/log.h>
JAVA層打?。?
importandroid.util.Log;
privatestaticfinalStringTAG="XX_LOG_TAG";
Log.e(TAG,"ThisistheerrorlogprintedbyLog.iinandroiduserspace.");
3、盒子上如何獲取log
a、進(jìn)入shell獲取log
adbkill-server
adbconnectdest-ip
adbshell【登錄shell】
mount-oremount/system/system【改變權(quán)限】
logcat>>1.log
命令行輸入CTRL+C回到cmd命令行,adbpullpath/1.log
b、直接在cmd命令行獲取log
adbconnect連上后;
adbshell
adblogcat>>path/1.log
操作完畢后
命令行輸入CTRL+C回到cmd命令行,adbpullpath/1.log
c、在terminal終端直接輸出log
回車切到shell
logcat[此時即可看到打印]
4、Eclipse環(huán)境下運(yùn)行(安裝了Android插件),那么直接可以在Eclipse就可以查看了
5、常用技巧
1、logcat中會打印【輸出級別+LOG_TAG名字+進(jìn)程字+打印的信息】可以充分利用這些信息分析問題
I/SystemServer(939):ActivityManager
I/ActivityManager(939):Memoryclass:96
E/AndroidRuntime(939):ErrorreportingWTF
第一列由Log.i(e/w..決定)或者LOGI/LOGE/LOGW...
第二列由LOG_TAG/TAG(JAVA)中決定,可以對于同一組模塊前相同的前綴[xxx]funtion這種命名
第三列是系統(tǒng)進(jìn)程號getpid()這值,打印線程值pthread_slef()
最后的就是自行增加的打印信息
2、調(diào)效效率或者執(zhí)行時間
1、建議重點(diǎn)的打印增加前綴,方便查找。以[######]
2、直接利用logcat輸出時間,調(diào)試執(zhí)行速度,分析效率
logcat-vtime【Displaythedate,invocationtime,priority/tag,andPIDoftheoriginatingprocess.】
1、linux內(nèi)核的log輸出
在標(biāo)準(zhǔn)的linux內(nèi)核開發(fā)過程中,使用printk,這是一個與printf輸出打印齊名的函數(shù),同樣提供格式化輸出功能,只是其有
打印級別且將信息保存到/proc/kmsg日志中,使用cat命令查看其信息[cat/proc/kmsg]
復(fù)制代碼 代碼如下:
<SPANstyle="COLOR:#003333;FONT-SIZE:14px">#defineKERN_EMERG"<0>"/*systemisunusable*/
#defineKERN_ALERT"<1>"/*actionmustbetakenimmediately*/
#defineKERN_CRIT"<2>"/*criticalconditions*/
#deinfeKERN_ERR"<3>"/*errorconditions*/
#deinfeKERN_WARNING"<4>"/*warningconditions*/
#deinfeKERN_NOTICE"<5>"/*normalbutsignificantcondition*/
#deinfeKERN_INFO"<6>"/*informational*/
#deinfeKERN_DEBUG"<7>"/*debug-levelmessages*/</SPAN>
2、android中l(wèi)og輸出
Android系統(tǒng)在用戶空間中提供了輕量級的logger日志系統(tǒng),它是在內(nèi)核中實(shí)現(xiàn)的一種設(shè)備驅(qū)動,與用戶空間的logcat工具配合使用能夠方便地跟蹤調(diào)試程序。
Android系統(tǒng)中的C/C++日志接口是通過宏來使用的。在system/core/include/android/log.h定義了日志的級別:
/*
*Androidlogpriorityvalues,inascendingpriorityorder.
*/
typedefenumandroid_LogPriority{
ANDROID_LOG_UNKNOWN=0,
ANDROID_LOG_DEFAULT,/*onlyforSetMinPriority()*/
ANDROID_LOG_VERBOSE,
ANDROID_LOG_DEBUG,
ANDROID_LOG_INFO,
ANDROID_LOG_WARN,
ANDROID_LOG_ERROR,
ANDROID_LOG_FATAL,
ANDROID_LOG_SILENT,/*onlyforSetMinPriority();mustbelast*/
}android_LogPriority;
為了使用方便,在system/core/include/cutils/log.h定義了相對應(yīng)的宏:
#defineLOGV(...)((void)LOG(LOG_VERBOSE,LOG_TAG,__VA_ARGS__))
#defineLOGD(...)((void)LOG(LOG_DEBUG,LOG_TAG,__VA_ARGS__))
#defineLOGI(...)((void)LOG(LOG_INFO,LOG_TAG,__VA_ARGS__))
#defineLOGW(...)((void)LOG(LOG_WARN,LOG_TAG,__VA_ARGS__))
#defineLOGE(...)((void)LOG(LOG_ERROR,LOG_TAG,__VA_ARGS__))
因?yàn)槿绻枰褂胠og輸出,包含其頭文件:#include<cutils/log.h>并link其動態(tài)庫:liblog.so即可
#defineLOG_TAG"XX_LOG_TAG"http://這里可以定義其輸出的TAG
#include<cutils/log.h>
JAVA層打?。?
importandroid.util.Log;
privatestaticfinalStringTAG="XX_LOG_TAG";
Log.e(TAG,"ThisistheerrorlogprintedbyLog.iinandroiduserspace.");
3、盒子上如何獲取log
a、進(jìn)入shell獲取log
adbkill-server
adbconnectdest-ip
adbshell【登錄shell】
mount-oremount/system/system【改變權(quán)限】
logcat>>1.log
命令行輸入CTRL+C回到cmd命令行,adbpullpath/1.log
b、直接在cmd命令行獲取log
adbconnect連上后;
adbshell
adblogcat>>path/1.log
操作完畢后
命令行輸入CTRL+C回到cmd命令行,adbpullpath/1.log
c、在terminal終端直接輸出log
回車切到shell
logcat[此時即可看到打印]
4、Eclipse環(huán)境下運(yùn)行(安裝了Android插件),那么直接可以在Eclipse就可以查看了

5、常用技巧
1、logcat中會打印【輸出級別+LOG_TAG名字+進(jìn)程字+打印的信息】可以充分利用這些信息分析問題
I/SystemServer(939):ActivityManager
I/ActivityManager(939):Memoryclass:96
E/AndroidRuntime(939):ErrorreportingWTF
第一列由Log.i(e/w..決定)或者LOGI/LOGE/LOGW...
第二列由LOG_TAG/TAG(JAVA)中決定,可以對于同一組模塊前相同的前綴[xxx]funtion這種命名
第三列是系統(tǒng)進(jìn)程號getpid()這值,打印線程值pthread_slef()
最后的就是自行增加的打印信息
2、調(diào)效效率或者執(zhí)行時間
1、建議重點(diǎn)的打印增加前綴,方便查找。以[######]
2、直接利用logcat輸出時間,調(diào)試執(zhí)行速度,分析效率
logcat-vtime【Displaythedate,invocationtime,priority/tag,andPIDoftheoriginatingprocess.】
您可能感興趣的文章:
- Android開發(fā)筆記之:Log圖文詳解(Log.v,Log.d,Log.i,Log.w,Log.e)
- android輕松管理安卓應(yīng)用中的log日志 發(fā)布應(yīng)用時log日志全部去掉的方法
- android雜記:C++文件的添加log方法分享
- Android將應(yīng)用調(diào)試log信息保存在SD卡的方法
- Android編程之基于Log演示一個activity生命周期實(shí)例詳解
- Android 實(shí)現(xiàn)自己的LOG信息
- microlog4android將Android Log日志寫到SD卡文件中實(shí)現(xiàn)方法
- Android 日志工具(log)的使用方法
- Android開發(fā)實(shí)現(xiàn)的Log統(tǒng)一管理類
相關(guān)文章
Android 實(shí)現(xiàn)調(diào)用系統(tǒng)照相機(jī)拍照和錄像的功能
這篇文章主要介紹了Android 實(shí)現(xiàn)調(diào)用系統(tǒng)照相機(jī)拍照和錄像的功能的相關(guān)資料,需要的朋友可以參考下2016-11-11Android開發(fā)之如何自定義數(shù)字鍵盤詳解
這篇文章主要給大家介紹了關(guān)于Android開發(fā)之如何自定義數(shù)字鍵盤的相關(guān)資料,本文語言是基于kotlin實(shí)現(xiàn)的,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-09-09android 上傳aar到私有maven服務(wù)器的示例
這篇文章主要介紹了android 上傳aar到私有maven服務(wù)器,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11Android中的popupwindow進(jìn)入和退出的動畫效果
這篇文章主要介紹了Android中的popupwindow進(jìn)入和退出的動畫,需要的朋友可以參考下2017-04-04Android?webView加載數(shù)據(jù)時內(nèi)存溢出問題及解決
這篇文章主要介紹了Android?webView加載數(shù)據(jù)時內(nèi)存溢出問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12Android賬號注冊實(shí)現(xiàn)點(diǎn)擊獲取驗(yàn)證碼倒計(jì)時效果
這篇文章主要為大家詳細(xì)介紹了Android賬號注冊過程中實(shí)現(xiàn)點(diǎn)擊獲取驗(yàn)證碼倒計(jì)時效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-05-05