本文的源碼請前往Github https://github.com/dragonjiang/HelloJni.git
導(dǎo)入log頭文件
在需要打印log的c/c++源文件中添加android/log.h頭文件
#include<android/log.h>
添加LOG宏定義
在引入android/log.h的源文件中先定義一個(gè)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
上述代碼中定義的方法分別對應(yīng)于Android中Java代碼的Log.d(), Log.i(), Log.w(),Log.e(), Log.f()等方法入蛆。
在build.gradle中添加庫
在app目錄下的build.gradle中設(shè)置要加載的log,在defaultConfig這項(xiàng)里面添加
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 !");
}
然后執(zhí)行Build->Make Project,
執(zhí)行Run->Run 'app'邦泄。
可以看到logcat輸出結(jié)果了:
Log方法還支持格式化輸出哦迹炼,
再加入
char *name = "JNI";
LOGD("My name is %s.", name);
查看logcat輸出結(jié)果: