有必要在项目*.so文件中包含从源代码中预先生成的文件。问题是:
生成的*.so文件应该存储在项目中(libs例如,在文件夹中),还是在应用程序启动时以某种方式编译?或者向 gradle 添加一些目标?或者写一个脚本从源代码生成?
那么,主要问题 - 这些方法中哪种最好?或者还有其他选择吗?
有必要在项目*.so文件中包含从源代码中预先生成的文件。问题是:
生成的*.so文件应该存储在项目中(libs例如,在文件夹中),还是在应用程序启动时以某种方式编译?或者向 gradle 添加一些目标?或者写一个脚本从源代码生成?
那么,主要问题 - 这些方法中哪种最好?或者还有其他选择吗?
我不确定我使用的是否是某种最佳实践,但该方案经受了数年并一直沿用至今。
1) gradle 以及 Android Studio 都无法与 JNI 配合使用——这是一个假设,我上次尝试是在六个月前——它仍然无法正常工作。在最新版本的gradle / Android Studio中,我不断看到现在终于改进了JNI支持,但还没有时间检查它。
2)当然,
*.so文件应该存放在目录libs中,关键是*.so文件的生成不是一个快速且不频繁的过程,所以每次都重新生成它们是低于平均水平的。3) 实际上,对于
*.so库本身的生成,您可以使用常规的 NDK 构建脚本:ndk-build.cmd直接从控制台/终端,但我通常使用 ant 脚本build-ndk.xml,例如:其中
ndk.properties包含2个变量ndk.dir和ndk.build-NDK所在的地方和ndk-buildNDK收集器的平台特定脚本的名称为了完成图片,可以将此脚本导入 gradle:
然后 2 个新目标将出现在 gradle 任务列表中:
buildJni和cleanJni,它们可以很容易地从 gradle 启动。如果你真的需要 ant 导入,你可以强加依赖,然后buildJni当你更改源代码时它会自动启动。首先,您需要“静音”
jni/ndkgradle 中的支持尝试并指定*.so库所在的位置:像这样的东西。