转载地址: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
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错误,这里仅显示红色的错误信息,这些错误就需要我们认真的分析,查看栈的信息了。
新闻热点
疑难解答