jni 的静态方法导入,在新建的项目中添加jni
Step 1:
降低gradle的版本,在project的build.gradle文件中(目前的AS新版本使用CMake,这种方式只能采用低版本的)
dependencies {
classpath 'com.android.tools.build:gradle:2.3.3'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
指定 buildToolsVersion '25.0.2',由于上方的gradle 版本降低引起的。
依赖库额引用关键字使用compile。
在gradle.properties文件中添加android.useDepreCatedNdk=true
在module的build.gradle文件中加入ndk的节点,借助moduleName的值
ndk {
moduleName "jniTest"
}
Step 2:
新建一个JAVA类含有native的方法。
public class JniUtil {
/* static {
System.loadLibrary("jniTest");
}*///先暂时不添加
public native String getString();
}
make Module一次,在app下的build中找到对应的class文件,使用Javah -jni生成头文件。具体步骤为,进入classes下的debug目录,此处展示了包的开始,执行javah -jni com.stu.ruiz.JniUtil.生成一个“.h"文件.将其移动到main下的一个新建文件夹jni。
Step 3:
依赖于头文件新建cpp文件(需要注意 JNIEnv *env这个参数,在第一次形成时是没有后面的env的)
/* DO NOT EDIT THIS FILE - it is machine generated */
#include "cn_stu_cusview_ruiz_jnidemo_JniUtil.h"
/*
* Class: cn_stu_cusview_ruiz_jnidemo_JniUtil
* Method: getString
* Signature: ()Ljava/lang/String;
*/
JNIEXPORT jstring JNICALL Java_cn_stu_cusview_ruiz_jnidemo_JniUtil_getString
(JNIEnv *env, jobject){
return env->NewStringUTF("Hi ! I am jni.");
}
Step 4:
在 JniUtil中放开注释加载库文件部分。
在代码中使用,new JniUtil().getString().