AndroidStudio新建HelloJNI

2017-03-15  本文已影响0人  不解释sdx

一 新建一个HelloJNI项目

图1

二 在MainActivity中创建要使用的JNI方法

图2

static{System.loadLibrary("hello_jni");}

这个是用来加载本地的library库.请记住"hello_jni",这个后面在gradle中要使用到.

三 使用jdk生成c++文件

1.打开androidStudio的Terminal窗口,输入javah查看jdk是否配置正确,如果不正确请参照jdk环境变量配置 .

2.使用命令进入到项目的java目录.

cd app\src\main\java

3.使用命令生成c++文件

javah -encoding utf-8 -jni com.zrb.hellojni.MainActivity

第一个参数是编译的时候使用utf-8的编码,如果不加可能会出现编码错误,第二个参数jni后面是想要生成jni的类名.如果看到java目录下面生成一个com_zrb_hellojni_MainActivity.h的文件就是编译成功.这就是目标的c++文件.

图3

四 在MainActivity中获取到JNI返回的数据

1.在main文件夹下新建一个资源文件夹,并且把生成出来的com_zrb_hellojni_mainActivity.h放入其中.

图4

2.在build.gradle的defaultConfig中加入如下的代码,其中"hello_jni",就是之前在MainActivity中设置的名称,abiFilters就是所要支持的cpu型号.

ndk {moduleName"hello_jni"

abiFilters"armeabi","armeabi-v7a","x86"}

3.在gradle.properties中加入一下这段代码.表示支持NDK库.

android.useDeprecatedNdk=true

4.编写com_zrb_hellojni_mainActivity.h中的c++代码.

图5

上面我们要关心的就是两个方法,

JNIEXPORT jstring JNICALL Java_com_zrb_hellojni_MainActivity_helloJni

(JNIEnv *,jclass);

JNIEXPORT jint JNICALL Java_com_zrb_hellojni_MainActivity_addCalc

(JNIEnv *,jclass,jint,jint);

这两个方法就是在MainActivity中的helloJni();和addCalc(inta, intb);接下来给这两个方法加上方法体和参数名.

JNIEXPORT jstring JNICALL Java_com_zrb_hellojni_MainActivity_helloJni

(JNIEnv * env,jclass jcl){

return env->NewStringUTF("hello jni");

};

JNIEXPORT jint JNICALL Java_com_zrb_hellojni_MainActivity_addCalc

(JNIEnv * env,jclass jcl,jint a,jint b){

return a+b;

};

最后要把com_zrb_hellojni_mainActivity.h的后缀修改成cpp,就是com_zrb_hellojni_mainActivity.cpp.然后运行代码.就能在MainActivity中看到jni返回的数据

图6

五 总结

最后编译成功的so文件会在app\build\intermediates\ndk\debug\lib下面.这里面的so文件可以导入项目中使用.

图7

项目已分享到github HelloJNI .

上一篇下一篇

猜你喜欢

热点阅读