首页 > 学院 > 开发设计 > 正文

jni中的日志输出到LOGCAT

2019-11-08 00:12:20
字体:
来源:转载
供稿:网友

转载地址:http://blog.csdn.net/xunice/article/details/34852489

java环境下使用JNI时可以方便的使用PRintf函数打印信息,在Eclipse控制台Console视图可以方便的观察到,可在Android环境下使用JNI的话,printf函数就无效了,LogCat视图和Console视图里看不到任何输出.但在android编程java代码中,我们使用Log.v等一些将日志输出到logcat,在LogCat视图中可以看到日志输出信息。

android NDK完全支持JNI本地方法调试。它提供4个android_log_XXX函数供我们使用。路径:/build/platforms/android-X/arch-arm/usr/include/android/log.h

在这个头文件中,会看到以下定义:

[cpp] view plain copyprint?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错误,这里仅显示红色的错误信息,这些错误就需要我们认真的分析,查看栈的信息了。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表