步骤:
1:创建好一个完整的工程。
2:把一些必须的代码事先写好:在项目(app)的build.gradel中的defaultConfig下添加。没有下载NKD的,要下载ndk。
ndk{
moduleName "helper" //生成的so名字
ldLibs "log", "z", "m" //添加依赖库文件,因为有log打印等
abiFilters "arm64-v8a","armeabi", "armeabi-v7a","mips","mips64","x86_64", "x86"
//输出指定几种abi体系结构下的so库。
}
在gradle.properties文件中添加:
android.useDeprecatedNdk=true
添加jni文件夹:
3:新建一个文件夹,在里面新建一个类(文件夹和类名称尽量大众化,方便以后更多项目的引用。)
例如:类中可以添加如下方法:
public class JniUtils {
public static native String getStringFormC();
}
然后clean project 再rebuild project 生成class文件,
这时候打开如下图的文件夹看是否生成了classes文件夹,没有生成请重新来过。
再打开Terminal输入指令
cd app/build/intermediates/classes/debug
然后再输入指令
javah -jni com.yyh.fork.NativeRuntime
注意 这里javah -jni后面跟的是JniUtils类的全路径,如果javah报不存在之类的,是你的java环境没有配置好。
这时候打开classes/debug下面的文件发现多了一个文件
然后在打开src/main下新建好的文件夹jni,把生成的.h文件复制或者剪切到jni文件夹下面去,新建一个c类随便取一个名字,添加代码如下
在NativeRuntime类里面添加如下代码:
static {
System.loadLibrary("helper");//之前在build.gradle里面设置的so名字,必须一致
}
最后:组建apk或者运行代码,会在这里会生成so库:
新建libs文件夹把这三个文件夹放进去,或者这样:
然后删除咱们的jni文件试试,是否工程还能运行?
答案当然是能运行的!这个so库还能用到别的项目中去,前提就是与步骤3的文件名和路径要一样。