关于JNI引入的一些问题

上一篇文章中 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'
        }
    }

}


猜你喜欢

转载自blog.csdn.net/u010349644/article/details/80821921
今日推荐