浅谈Android系统开发中LOG的使用

在程序开发过程中,LOG是广泛使用的用来记录程序执行过程的机制,它既可以用于程序调试,也可以用于产品运营中的事件记录。在Android系统中,提供了简单、便利的LOG机制,开发人员可以方便地使用。在这一篇文章中,我们简单介绍在Android内核空间和用户空间中LOG的使用和查看方法。

       一.内核开发时LOG的使用。Android内核是基于Linux Kerne 2.36的,因此,LinuxKernel的LOG机制同样适合于Android内核,它就是有名的printk,与C语言的printf齐名。与printf类似,printk提供格式化输入功能,同时,它也具有所有LOG机制的特点--提供日志级别过虑功能。kernel提供了(include\linux\printk.h) printk提供了8种日志级别():只要包含头文件 #inlcude即可

 

[cpp]  viewplain copy
  1. #define KERN_EMERG  "<0>"       
  2. #define KERN_ALERT  "<1>"       
  3. #define KERN_CRIT   "<2>"       
  4. #deinfe KERN_ERR    "<3>"       
  5. #deinfe KERN_WARNING    "<4>"       
  6. #deinfe KERN_NOTICE "<5>"       
  7. #deinfe KERN_INFO   "<6>"       
  8. #deinfe KERN_DEBUG  "<7>"       
      printk的使用方法:

 

      printk(KERN_ALERT"Thisis the log printed by printk in linux kernel space.");

      KERN_ALERT表示日志级别,后面紧跟着要格式化字符串。

     在Android系统中,printk输出的日志信息保存在/proc/kmsg中,要查看/proc/kmsg的内容,

      root@android:/ # cat /proc/kmsg

      二.用户空间程序开发时LOG的使用。Android系统在用户空间中提供了轻量级的logger日志系统,它是在内核中实现的一种设备驱动,与用户空间的logcat工具配合使用能够方便地跟踪调试程序。在Android系统中,分别为C/C++和Java语言提供两种不同的logger访问接口。C/C++日志接口一般是在编写硬件抽象层模块或者编写JNI方法时使用,而Java接口一般是在应用层编写APP时使用。

     Android系统中的C/C++日志接口是通过宏来使用的。在system/core/include/android/log.h定义了日志的级别:

 

[cpp]  viewplain copy
  1.   
  2. typedef enum android_LogPriority  
  3.     ANDROID_LOG_UNKNOWN 0,  
  4.     ANDROID_LOG_DEFAULT,      
  5.     ANDROID_LOG_VERBOSE,  
  6.     ANDROID_LOG_DEBUG,  
  7.     ANDROID_LOG_INFO,  
  8.     ANDROID_LOG_WARN,  
  9.     ANDROID_LOG_ERROR,  
  10.     ANDROID_LOG_FATAL,  
  11.     ANDROID_LOG_SILENT,   
  12. android_LogPriority;  
     在system/core/include/cutils/log.h中,定义了对应的宏,如对应于ANDROID_LOG_VERBOSE的宏LOGV:

 

 

[cpp]  viewplain copy
  1.   
  2. #ifndef LOG_TAG  
  3. #define LOG_TAG NULL  
  4. #endif  
  5.   
  6.   
  7. #ifndef LOGV  
  8. #if LOG_NDEBUG  
  9. #define LOGV(...)   ((void)0)  
  10. #else  
  11. #define LOGV(...)   ((void)LOG(LOG_VERBOSE, LOG_TAG, __VA_ARGS__))  
  12. #endif  
  13. #endif  
  14.   
  15.   
  16. #ifndef LOG  
  17. #define LOG(priority, tag, ...) \  
  18.      LOG_PRI(ANDROID_##priority, tag, __VA_ARGS__)  
  19. #endif  
  20.   
  21.   
  22. #ifndef LOG_PRI  
  23. #define LOG_PRI(priority, tag, ...) \  
  24.      android_printLog(priority, tag, __VA_ARGS__)  
  25. #endif  
  26.   
  27.   
  28. #define android_printLog(prio, tag, fmt...) \  
  29.      __android_log_print(prio, tag, fmt)  
        因此,如果要使用C/C++日志接口,只要定义自己的LOG_TAG宏和包含头文件system/core/include/cutils/log.h就可以了:

 

       #define LOG_TAG "MY LOGTAG"

       #include

       就可以了,例如使用ALOGV:

       ALOGV("This is the logprinted by LOGV in android user space.");

       再来看Android系统中的Java日志接口。Android系统在Frameworks层中定义了Log接口(frameworks/base/core/java/android/util/Log.java):

 

[java]  viewplain copy
  1. ................................................  
  2.   
  3. public final class Log  
  4.   
  5. ................................................  
  6.   
  7.       
  8.     public static final int VERBOSE 2 
  9.   
  10.       
  11.     public static final int DEBUG 3 
  12.   
  13.       
  14.     public static final int INFO 4 
  15.   
  16.       
  17.     public static final int WARN 5 
  18.   
  19.       
  20.     public static final int ERROR 6 
  21.   
  22.       
  23.     public static final int ASSERT 7 
  24.   
  25. .....................................................  
  26.   
  27.     public static int v(String tag, String msg)  
  28.         return println_native(LOG_ID_MAIN, VERBOSE, tag, msg);  
  29.      
  30.   
  31.     public static int v(String tag, String msg, Throwable tr)  
  32.         return println_native(LOG_ID_MAIN, VERBOSE, tag, msg '\n' getStackTraceString(tr));  
  33.      
  34.   
  35.     public static int d(String tag, String msg)  
  36.         return println_native(LOG_ID_MAIN, DEBUG, tag, msg);  
  37.      
  38.   
  39.     public static int d(String tag, String msg, Throwable tr)  
  40.         return println_native(LOG_ID_MAIN, DEBUG, tag, msg '\n' getStackTraceString(tr));  
  41.      
  42.   
  43.     public static int i(String tag, String msg)  
  44.         return println_native(LOG_ID_MAIN, INFO, tag, msg);  
  45.      
  46.   
  47.     public static int i(String tag, String msg, Throwable tr)  
  48.         return println_native(LOG_ID_MAIN, INFO, tag, msg '\n' getStackTraceString(tr));  
  49.      
  50.   
  51.     public static int w(String tag, String msg)  
  52.         return println_native(LOG_ID_MAIN, WARN, tag, msg);  
  53.      
  54.   
  55.     public static int w(String tag, String msg, Throwable tr)  
  56.         return println_native(LOG_ID_MAIN, WARN, tag, msg '\n' getStackTraceString(tr));  
  57.      
  58.   
  59.     public static int w(String tag, Throwable tr)  
  60.         return println_native(LOG_ID_MAIN, WARN, tag, getStackTraceString(tr));  
  61.      
  62.       
  63.     public static int e(String tag, String msg)  
  64.         return println_native(LOG_ID_MAIN, ERROR, tag, msg);  
  65.      
  66.   
  67.     public static int e(String tag, String msg, Throwable tr)  
  68.         return println_native(LOG_ID_MAIN, ERROR, tag, msg '\n' getStackTraceString(tr));  
  69.      
  70.   
  71. ..................................................................  
  72.   
  73.      public static native int println_native(int bufID,  
  74.         int priority, String tag, String msg);  
  75.  

 

      因此,如果要使用Java日志接口,只要在类中定义的LOG_TAG常量和引用android.util.Log就可以了:

      private static final String LOG_TAG ="MY_LOG_TAG";

      Log.i(LOG_TAG, "This is the log printed by Log.iin android user space.");

      要查看这些LOG的输出,可以配合logcat工具。如果是在Eclipse环境下运行模拟器,并且安装了Android插件,那么,很简单,直接在Eclipse就可以查看了:

       

       如果是在自己编译的Android源代码工程中使用,则在后台中运行模拟器:

      USER-NAME@MACHINE-NAME:~/Android$emulator &

      启动adb shell工具:

      USER-NAME@MACHINE-NAME:~/Android$adb shell

      使用logcat命令查看日志:

      root@android:/ #logcat

      这样就可以看到输出的日志了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值