下载NDK及构建工具
在打开的项目中,从菜单栏选择 Tools > Android > SDK Manager。
点击 SDK Tools 标签。
选中 LLDB、CMake 和 NDK 旁的复选框,从 SDK 管理器中安装 LLDB、CMake 和 NDK。
点击 Apply,然后在弹出式对话框中点击 OK。
安装完成后,点击 Finish,然后点击 OK。
CMakeLists.txt文件编写
在src\main\目录下新建一个名为jni的目录(名称和父目录可以随意)
在src\main\jni\目录内新建一个名称为CMakeLists.txt的文件(该文件名称固定为CMakeLists.txt)
文件内容为
cmake_minimum_required(VERSION 3.4.1)
find_library(log-lib log)
点击IDE菜单File -> Link C++ Project with Gradle
Build System选择CMake
Project Path选择上面创建的CMakeLists.txt
实际上就是在app的build.gradle的android节中新增了
externalNativeBuild {
cmake {
path 'src/main/jni/CMakeLists.txt'
}
}
注意:如果报以下错误
Error:Execution failed for task ':app:preDebugAndroidTestBuild'.
> Conflict with dependency 'com.android.support:support-annotations' in project ':app'. Resolved versions for app (26.1.0) and test app (27.1.1) differ. See https://d.android.com/r/tools/test-apk-dependency-conflicts.html for details.
rebuild project一下项目就OK了。
尝试编写JNI并引用
在src\main\jni\目录内新建一个c文件jnitext.c,在文件中添加
#include <jni.h>
接下来在CMakeLists.txt文件中添加
add_library(jnitext SHARED jnitext.c)
target_link_libraries(jnitext ${log-lib})
注意这两行代码不能颠倒,负责build会报错。
接下来在我们的java中引用
static {
System.loadLibrary("jnitext");
}
public native String helloJni();
鼠标点击放到native函数上
会提示Cannot resolve corresponding JNI function Java_com_example_jiang_hellojnitest_MainActivity_helloJni
按Alt + Enter点击Create...
在c文件中自动创建函数
JNIEXPORT jstring JNICALL
Java_com_example_jiang_hellojnitest_MainActivity_helloJni(JNIEnv *env, jobject instance) {
// TODO
return (*env)->NewStringUTF(env, returnValue);
}
用一个TextView显示jni函数的结果运行即可看到jni函数成功执行。
结束。
笔者能力有限,不足之处欢迎指出。