Android Stuido Ndk-Jni 开发(二):Jni中打印log信息

本文的源码请前往Github https://github.com/dragonjiang/HelloJni.git

导入log头文件

在需要打印log的c/c++源文件中添加android/log.h头文件

#include<android/log.h>

添加LOG宏定义

在引入android/log.h的源文件中先定义一个LOG_TAG,再添加Log的宏定义,方便使用:

#ifndef LOG_TAG
#define LOG_TAG "HELLO_JNI"
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG ,__VA_ARGS__) // 定义LOGD类型
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG ,__VA_ARGS__) // 定义LOGI类型
#define LOGW(...) __android_log_print(ANDROID_LOG_WARN,LOG_TAG ,__VA_ARGS__) // 定义LOGW类型
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG ,__VA_ARGS__) // 定义LOGE类型
#define LOGF(...) __android_log_print(ANDROID_LOG_FATAL,LOG_TAG ,__VA_ARGS__) // 定义LOGF类型
#endif

上述代码中定义的方法分别对应于Android中Java代码的Log.d(), Log.i(), Log.w(),Log.e(), Log.f()等方法。

在build.gradle中添加库

在app目录下的build.gradle中设置要加载的log,在defaultConfig这项里面添加

        ndk {
            moduleName "HelloJni" //编译后会生成HelloJni.so
            ldLibs "log", "z", "m"
        }

打印Log

在代码中直接使用

LOGD("LOG from JNI");

完整代码如下:

//
// Created by DRAGON-JIANG on 2016/2/17.
//
#include <jni.h>
#include<android/log.h>

#ifndef LOG_TAG
#define LOG_TAG "HELLO_JNI"
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG ,__VA_ARGS__) // 定义LOGD类型
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG ,__VA_ARGS__) // 定义LOGI类型
#define LOGW(...) __android_log_print(ANDROID_LOG_WARN,LOG_TAG ,__VA_ARGS__) // 定义LOGW类型
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG ,__VA_ARGS__) // 定义LOGE类型
#define LOGF(...) __android_log_print(ANDROID_LOG_FATAL,LOG_TAG ,__VA_ARGS__) // 定义LOGF类型
#endif

/*
 * Class:     com_dj_jni_hellojni_NativeHelper
 * Method:    getStringFromJni
 * Signature: ()Ljava/lang/String;
 */
JNIEXPORT jstring JNICALL Java_com_dj_jni_hellojni_NativeHelper_getStringFromJni
        (JNIEnv *env, jobject obj){

    LOGD("LOG from JNI");

    return (*env)->NewStringUTF(env,"Hello from JNI !");
}

然后执行Build->Make Project,
执行Run->Run 'app'。
可以看到logcat输出结果了:

Log方法还支持格式化输出哦,
再加入

    char *name = "JNI";
    LOGD("My name is %s.", name);

查看logcat输出结果:

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 131,934评论 20 560
  • afinalAfinal是一个android的ioc,orm框架 https://github.com/yangf...
    passiontim阅读 9,826评论 2 43
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 79,665评论 12 120
  • 文/墨雪 黑夜,遗落一个小生命 一定是自己那断了身体的手指头 樱花替我寻找它 牛羊,牧人,田野都在寻找它 黑夜,我...
    我是家瑞阅读 100评论 9 21
  • 出版近一个月狂销4万册,豆瓣评分高达8.5,李笑来、万维钢、脱不花、战隼、易仁永澄等多位网络大牛鼎力推荐…《好好学...
    虚室阅读 142评论 1 4