android平台的jni中的日志输出到LOGCAT实例介绍



android平台的jni中的日志输出到LOGCAT实例介绍。安卓平台如何输出日记信息?Java环境下使用JNI时可以使用printf函数打印,Eclipse IDE开发工具控制台Console视图可观察到,但是Android环境下使用JNI,printf函数就无效了,LogCat视图以及Console视图里没有任何输出.在android编程java代码里面,使用Log.v等一些将日志输出到logcat,在LogCat视图中可以看到日志输出信息。

android NDK完全支持JNI本地方法调试。它提供4个android_log_XXX函数供我们使用。
路径:/build/platforms/android-8/arch-arm/usr/include/android/log.h
在这个头文件中,可以看到以下定义:
typedef enum android_LogPriority {
ANDROID_LOG_UNKNOWN = 0,
ANDROID_LOG_DEFAULT,
ANDROID_LOG_VERBOSE,
ANDROID_LOG_DEBUG,
ANDROID_LOG_INFO,
ANDROID_LOG_WARN,
ANDROID_LOG_ERROR,
ANDROID_LOG_FATAL,
ANDROID_LOG_SILENT,
} android_LogPriority;

int __android_log_write(int prio, const char *tag, const char *text);

int __android_log_print(int prio, const char *tag, const char *fmt, …)
#if defined(__GNUC__)
__attribute__ ((format(printf, 3, 4)))
#endif
;

int __android_log_vprint(int prio, const char *tag,
const char *fmt, va_list ap);

void __android_log_assert(const char *cond, const char *tag,
const char *fmt, …)

设置输出log信息的步骤,然后就可以通过log去调试jni代码了
1 添加ndk对log支持
若需要添加ndk对log的支持,只需要通过以下2步即可实现。
1.1 修改Android.mk
如生成的库文件是“.so文件”,则在Android.mk中添加如下内容:
LOCAL_LDLIBS:=-L$(SYSROOT)/usr/lib -llog
如生成的库文件是“.a文件”,则在Android.mk中添加如下内容:
LOCAL_LDLIBS:=-llog
1.2 在.c或.cpp文件中引用log头文件
添加如下内容:
// 引入log头文件
#include
// log标签
#define TAG “hello_load”
// 定义info信息
#define LOGI(…) __android_log_print(ANDROID_LOG_INFO,TAG,__VA_ARGS__)
// 定义debug信息
#define LOGD(…) __android_log_print(ANDROID_LOG_DEBUG, TAG, __VA_ARGS__)
// 定义error信息
#define LOGE(…) __android_log_print(ANDROID_LOG_ERROR,TAG,__VA_ARGS__)
ANDROID_LOG_INFO:是日志级别;
TAG:是要过滤的标签,可以在LogCat视图中过滤。
__VA_ARGS__:是实际的日志内容。
完成上面2步之后,我们就可以在.c/cpp文件中添加LOGI、LOGD、LOGE去打印信息!使用LOGI、LOGD、LOGE的方法和使用printf一样
1.3日志类型
1)Log.v 的调试颜色为黑色的,任何消息都会输出,这里的v代表verbose啰嗦的意思,平时使用就是Log.v(,);
2)Log.d的输出颜色是蓝色的,仅输出debug调试的意思,但他会输出上层的信息,过滤起来可以通过DDMS的Logcat标签来选择
3)Log.i的输出为绿色,一般提示性的消息information,它不会输出Log.v和Log.d的信息,但会显示i、w和e的信息
4)Log.w的意思为橙色,可以看作为warning警告,一般需要我们注意优化Android代码,同时选择它后还会输出Log.e的信息。
5)Log.e为红色,可以想到error错误,这里仅显示红色的错误信息,这些错误就需要我们认真的分析,查看栈的信息了。

出处:http://blog.sina.com.cn/staratsky
作者:流星