简要介绍下自己在利用Android Studio开发JNI时的步骤和遇到的问题

1.创建一个Android工程,在MainActivity里面定义一个native方法,如下:

public  native  String stringFromJNI();

2.执行Build->Make Project生存MainActivity的class文件

在studio的Terminal的窗口进入到“app/src/main”目录下面,执行下面的命令就可以生成对应的.h文件

javah -d jni -classpath ../../build/intermediates/classes/debug acitvity.jason.com.jnidemo1.MainActivity

编写自己的.c文件,主要功能是返回一个String,如下

/* DO NOT EDIT THIS FILE - it is machine generated */#include #include /* Header for class acitvity_jason_com_jnidemo1_MainActivity */#ifndef _Included_acitvity_jason_com_jnidemo1_MainActivity#define _Included_acitvity_jason_com_jnidemo1_MainActivity#ifdef __cplusplusextern "C" {#endif/* * Class:     acitvity_jason_com_jnidemo1_MainActivity * Method:    stringFromJNI * Signature: ()Ljava/lang/String; */JNIEXPORT jstring JNICALL Java_acitvity_jason_com_jnidemo1_MainActivity_stringFromJNI        (JNIEnv *env, jobject jobject){           return (*env)->NewStringUTF(env, "Hello From JNI!");}#ifdef __cplusplus}#endif#endif

3.在项目中配置ndk环境

在 local.properties 文件中设置ndk的路径:

ndk.dir=your_path/android-ndk-r10e
在app目录下的 build.gradle中设置库文件名(生成的so文件名),在defaultConfig分支中增加上

defaultConfig {        applicationId "acitvity.jason.com.jnidemo1"        minSdkVersion 11        targetSdkVersion 22        versionCode 1        versionName "1.0"        ndk{            moduleName "hello-jni"//配置生成的so库名称            abiFilters "armeabi", "armeabi-v7a", "x86" //指定三种abi体系结构下的so库        }    }


4.在MainActivity中加载库文件

static {        System.loadLibrary("hello-jni");    }
运行截图如下
利用Android studio开发JNI工程_第1张图片

5.使用__android_log_print输出Log

在hello-jni.c文件中添加如下代码

#ifndef LOG_TAG#define LOG_TAG "ANDROID_LAB"#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)#endif

在需要打印日志的地方调用LOGE

JNIEXPORT jstring JNICALL Java_acitvity_jason_com_jnidemo1_MainActivity_stringFromJNI        (JNIEnv *env, jobject jobject){        LOGE("log string from ndk");      return (*env)->NewStringUTF(env, "Hello From JNI!");}

这样编译的话会报错: undefined reference to `__android_log_print 

需要在app/build.gradle的defaultConfig分支里修改NDK的配置如下

 ndk{            moduleName "hello-jni" //配置生成的so库名称            ldLibs "log"//实现__android_log_print            abiFilters "armeabi", "armeabi-v7a", "x86" //指定三种abi体系结构下的so库        }
这样运行就能打印出我们自己加的log了,如有需要,源代码上传到scdn上,你可以自己 下载







更多相关文章

  1. android 6.0后usb otg设备不显示在文件管理器中
  2. 将Activity打包成jar文件
  3. Android学习笔记(六)-文件操作与SDCard读写访问
  4. Android实现在xml文件中引用自定义View的方法分析
  5. AndroidStudioSDK下tools下各个文件(夹)的用处
  6. android 存储数据与文件

随机推荐

  1. Nginx如何支持HTTPS?手把手教贼简单!
  2. 40K+Star!Mall电商实战项目开源回忆录!
  3. mall-swarm微服务电商系统如何部署?用Jenk
  4. Github标星 8K+,免费又好用的Redis客户端
  5. 简单的路径规划案例分享
  6. 还在手写任务调度代码?试试这款可视化分布
  7. 还在百度Docker命令?推荐一套我用起来特顺
  8. SharePoint 解决方案:如何获取所有List Te
  9. 还在手动整合Swagger?Swagger官方Starter
  10. Swagger界面丑、功能弱怎么破?用Postman增