将C文件通过NDK编译生成SO库

NDK开发流程

1.安装NDK

将C文件通过NDK编译生成SO库_第1张图片
Paste_Image.png

下载完成后

将C文件通过NDK编译生成SO库_第2张图片
Paste_Image.png

2.配置
然后你会在local.properties文件中看到(或者自己添加):

Paste_Image.png

还有gradle.porperties里必须添加

android.useDeprecatedNdk=true

2.Java本地调用

public class NativeUtils {
static { System.loadLibrary("hello");
}
//java调C中的方法都需要用native声明且方法名必须和c的方法名一样
public native String getStringFromNative();}

继续如下 Make Project编译成class文件:


Paste_Image.png

然后我们在此

将C文件通过NDK编译生成SO库_第3张图片
Paste_Image.png

然后我们开始生成.h文件,通过Terminal终端或者直接ALT+F12

将C文件通过NDK编译生成SO库_第4张图片
Paste_Image.png

然后在命令行中;

先进入工程main目录下
输入自己的Native.class文件的绝对路径
javah -d jni -classpath class路径 包名+类名

例如:
javah -d jni -classpath D:\StudioSpace\JNITest\app\build\intermediates\classes\debug demo.pingkoko.cn.jnitest.NativeUtils

注意debug后面要留空格

将C文件通过NDK编译生成SO库_第5张图片
Paste_Image.png

成功之后会在main目录下自动创建jni文件夹以及生成的.h文件,.h文件不需要修改

将C文件通过NDK编译生成SO库_第6张图片
Paste_Image.png

接着我们要创建一个.c文件,命名必须和loadLibrary()里面参数一样 如下图:

将C文件通过NDK编译生成SO库_第7张图片
Paste_Image.png

c文件添加,必须要导入头文件.h

include

JNIEXPORT jstring JNICALL Java_demo_pingkoko_cn_jnitest_NativeUtils_getStringFromNative
(JNIEnv , jobject){
return (
env)->newStringUTF(env,"这是我测试的");
}

将C文件通过NDK编译生成SO库_第8张图片
Paste_Image.png

最后在build.gradle defaultConfig里面添加NDK配置:

//ndk编译生成.so文件
ndk { moduleName "test"
abiFilters "armeabi", "armeabi-v7a", "x86", "mips"
}

根目录下添加so库目录:

sourceSets {
main {
//你的源码目录
jniLibs.srcDirs 'src/main/libs'
jni.srcDirs = [] }
}

如图:

将C文件通过NDK编译生成SO库_第9张图片
Paste_Image.png

我们来运行看下;

将C文件通过NDK编译生成SO库_第10张图片
Paste_Image.png
将C文件通过NDK编译生成SO库_第11张图片
Paste_Image.png

so库所在的路径:


将C文件通过NDK编译生成SO库_第12张图片
Paste_Image.png

最后:C文件里面的返回类型是根据Native里面的返回值,如果java返回int,那么c里面就是jint具体可以自行搜索JNI语法。

你可能感兴趣的:(将C文件通过NDK编译生成SO库)