Android JNI打印Log

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”);

  1. 第一个参数取如下值:
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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值