[Android Studio]现有项目中完美引入JNI方案

下载NDK及构建工具

  1. 在打开的项目中,从菜单栏选择 Tools > Android > SDK Manager

  2. 点击 SDK Tools 标签。

  3. 选中 LLDBCMakeNDK 旁的复选框,从 SDK 管理器中安装 LLDB、CMake 和 NDK。

  4. 点击 Apply,然后在弹出式对话框中点击 OK

  5. 安装完成后,点击 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函数成功执行。

结束。

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

    原文作者:麦兜叮叮当
    原文地址: https://www.jianshu.com/p/39c88ba80769
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞