上一篇文章中 JNI入门-第一个实例,我们讲述了 Java层native方法-->jni层-->native层代码编写及调用关系,基本上展现了NDK开发的所有步骤流程,但是在实际的开发中,还是有一定的区别,例如
static {
//名字必须和build.gradle中的moduleName一致
try {
System.loadLibrary("MyFirstJinTest");
Log.i("JNI", "MyFirstJinTest load success");
} catch (Exception e) {
Log.e("JNI", "MyFirstJinTest load error");
e.printStackTrace();
}
}
这样的代码一般不会写到activity中,同时我们的项目中一般不会包含.c .h等文件,我们基本上都是直接依赖so文件来加载native库。
那么具体是怎样添加相关so文件的呢?
方法一:
在上一篇文章中,我们在build文件夹下可以看到libMyFirstJinTest.so文件,接下来,我们在src/main文件夹下创建jniLibs文件夹,最终结果如下:
然后在 MyFirstJniTest 添加如下代码:
public class MyFirstJniTest {
static {
try {
System.loadLibrary("MyFirstJinTest");
Log.i("JNI", "MyFirstJinTest load success");
} catch (Exception e) {
Log.e("JNI", "MyFirstJinTest load error");
e.printStackTrace();
}
}
public static native String getString();
public static native int add(int a, int b);
}
需要注意的是MyFirstJniTest 所在的包名和 产生so文件时必须是一样的,否则会出现找不到对应的native方法。
Activity中调用方式和之前一样,如下
String text = MyFirstJniTest.getString();
int sum = MyFirstJniTest.add(1, 2);
tvShowInfo.setText(text+" "+sum);
以上方式 是一个引入so文件和调用native层方法的正确使用方式。
方法二
有时候,我们并不想让我们的so文件在jniLibs文件夹中,而是在libs文件夹中,如下:
这样我们需要在APP下的build.gradle文件中,指定jni目录,具体指定方式如下:
android {
compileSdkVersion 24
buildToolsVersion "24.0.3"
………………………………
sourceSets {
main {
jniLibs.srcDir 'libs'
}
}
}