Android 日志系统(Logcat)的实现分析

本文详细分析了Android日志系统Logcat的实现,包括4个缓冲区(MAIN, RADIO, EVENTS, SYSTEM)和6个打印等级。Logcat通过JNI调用Liblog本地库,或直接调用C/C++本地库,最终由/system/bin/logcat工具读取设备驱动文件输出日志。在Java和C/C++中添加日志的方式也进行了介绍。" 112311829,10536502,R语言使用limma包进行差异基因分析及火山图绘制,"['R语言', '生物信息学', '基因分析', '数据预处理', '差异表达']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前转载了一篇 adb logcat 查看日志命令行用法 http://blog.youkuaiyun.com/ysh149216447/article/details/53374562,主要是在系统调试时Logcat这个工具的使用,

这篇说一下Android 日志系统的实现:

1. Android中的打印分为4个缓冲区和6个打印等级,在frameworks\base\core\java\android\util\Log.java中有定义:

四缓冲: 

 public static final int LOG_ID_MAIN = 0;

 public static final int LOG_ID_RADIO = 1; 

 public static final int LOG_ID_EVENTS = 2; 

 public static final int LOG_ID_SYSTEM = 3;

六等级:

 public static final int VERBOSE = 2; 

 public static final int DEBUG = 3; 

 public static final int INFO = 4; 

 public static final int WARN = 5;

 public static final int ERROR = 6; 

 public static final int ASSERT = 7;


2.Android Log打印有两种,一种是Java层添加的,一种是C/C++代码中添加的,如下图:


上图可以很容易看出,不管是java,还是C/C++,其实最终调用的driver接口都是一样的,java只是通过了jni调用了Android框架下实现的Liblog本地库,而C/C++则是直接调用的本地库。

Andorid Log的实现其实是一个典型的Android框架下的APK如何进行系统调用到驱动的实现。


3.从上面的流程可以很难清晰地知道Android代码中整个log的写入实现流程,而最终log输出最终的实现是/system/bin/logcat的一个工具。

其实/system/bin/logcat的实现也就是通过系统调用,读取的/dev/log/main/dev/log/radio/dev/log/events/dev/log/system四个驱动文件中的缓冲信息。

具体实现可以参考源码:/system/core/logcat/logcat.cpp


4. 最后说一下Android代码中添加打印

a. java中添加打印

import android.util.Log;

           使用Log.v()、Log.d()、Log.i()、Log.w()、Log.e()

b. C/C++中添加打印

两种方法:

第一种:

1、在Android工程的Android.mk文件中添加如下内容:
LOCAL_SHARED_LIBRARIES := liblog libutils  
LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog  
2、在JNI的实现代码文件(.c或者.cpp)中加入包含LOG头文件的如下代码:
#include <android/log.h>
3、在需要打印的方法中添加打印代码,例如:
__android_log_print(ANDROID_LOG_INFO, "JniX431FileTest", "lsx_init");
// ANDROID_LOG_INFO:是日志级别;
// "JniX431FileTest":是要过滤的标签,可以在LogCat视图中过滤。
// "lsx_init":是实际的日志内容。
#define LOGV(...) __android_log_print(ANDROID_LOG_VERBOSE, "ProjectName", __VA_ARGS__)
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG , "ProjectName", __VA_ARGS__)
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO  , "ProjectName", __VA_ARGS__)
#define LOGW(...) __android_log_print(ANDROID_LOG_WARN  , "ProjectName", __VA_ARGS__)
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR  , "ProjectName", __VA_ARGS__)
4、LOGV(...)、LOGD(...)、LOGI(...)、LOGW(...)、LOGE(...)
 
 也直接使用函数__android_log_print()

第二种、使用宏ALOGV、ALOGD、ALOGI、ALOGW、ALOGE   // 宏的实现在头文件android/log.h

例:ALOGW("%s : set OMX_IndexMstarTeePath failed!!", componentName.c_str());








评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值