Android(安卓)JNI打印Log
16lz
2021-01-26
1.Android.mk 文件的配置
LOCAL_LDLIBS += -llog
如果是使用Android Studio的NDK配置,在app中的build.gradle中的ndk的配置项中加入ldLibs "log"
ndk { moduleName "hello-jni" ldLibs "log" // 使用Android Log}
2.JNI层C/C++文件配置
需要添加输出函数的文件中加入头文件:
#include <android/log.h>
3.使用方法
__android_log_print(ANDROID_LOG_INFO, “tag”, “content”);
- 第一个参数取如下值:
typedef enum android_LogPriority { ANDROID_LOG_UNKNOWN = 0, ANDROID_LOG_DEFAULT, /* only for SetMinPriority() */ ANDROID_LOG_VERBOSE, ANDROID_LOG_DEBUG, ANDROID_LOG_INFO, ANDROID_LOG_WARN, ANDROID_LOG_ERROR, ANDROID_LOG_FATAL, ANDROID_LOG_SILENT, /* only for SetMinPriority(); must be last */} android_LogPriority;
- 第二个参数为tag
- 第三个参数为内容,支持格式化输出
如__android_log_print(ANDROID_LOG_INFO, “JNI_LOG”, “Tip: %s “, msg);
一般我们会声明一些宏来输出log,简化书写:
#ifndef LOG#define LOG_TAG "jni"#define ALOGD(...) \ __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__);#define ALOGE(...) \ __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__);#define ALOGV(...) \ __android_log_print(ANDROID_LOG_VERBOSE, LOG_TAG, __VA_ARGS__);#endif LOG
这样就可以使用ALOGD,ALOGE,ALOGV等来输出log
更多相关文章
- Android定时器Timer.schedule
- python logging 模块(一)
- Android(安卓)OPenCV 环境配置
- mac下配置android studio工具
- android 控制EditText字符长度[配置控制 代码控制]
- Android使用百度地图---环境配置和Hello World
- Android(安卓)Studio下载、安装和配置+SDK+tools下载(无敌超级详
- 发邮件
- Android(安卓)Looper And Hander 机制剖析 - 03