下载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

接下来在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函数成功执行。

结束。

笔者能力有限,不足之处欢迎指出。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐