相信很多人在刚开始学习Android JNI编程的时候,需要输出Log,在百度Google搜索的时候都是说需要在Android.mk中加入LOCAL_LDLIBS+= -L$(SYSROOT)/usr/lib -llog ,其实这是在eclipse开发上的方式,Android Studio并不是这么使用。
Android Studio的Android.mk是自动生成的,就算修改也是没用了,实际Android Studio的Android.mk是根据gradle文件生成的,那么就需要修改gradle文件。
如果不修改gradle,直接使用__android_log_print就会报错
Error:(36) undefined reference to '__android_log_print'
现在只需要在jni Module中得build.gradle 添加一些代码即可实现输出Log
build.gradle文件完成代码
apply plugin: 'com.android.library'android { compileSdkVersion 21 buildToolsVersion "21.1.2" defaultConfig { minSdkVersion 14 targetSdkVersion 21 versionCode 1 versionName "1.0" } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' ndk { moduleName "moduleName" ldLibs "log"//实现__android_log_print abiFilters "armeabi", "armeabi-v7a", "x86" } } } productFlavors { }}dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) compile 'com.android.support:support-v13:21.0.3'}
ldLibs "log" 是关键代码
#include <string.h>#include <android/log.h>#include <jni.h>#include <stdio.h>#define LOG_TAG "native-dev"#define LOGI(...) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__)#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)#define LOGI(...) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__)void testlog(){ LOGI("test");}
原标题:实现Android Studio JNI开发C/C++使用__android_log_print输出Log
关键词:Android