命令行形式开发JNI

一、确定native方法

新建一个类,拥有在里面写native方法, 如下:

public class NdkJniUtils {    // native方法    public native String getCLanguageString();  }

二,生成JNI方法头文件

可以用两种方法生成JNI方法头文件,但是建议使用ndk-build自动生成,这样不容易因为打错而造成无法使用so库。

  • 首先配置NDK环境变量:
    windows环境下,找到NDK所在目录,配置在path环境变量中即可,这里不多讲

  • 点击 android studio 工具栏 Build-make project 选项,编译生成 class 二进制文件,生成的文件在:

    D:\HelloNdk\app\build\intermediates\classes\debug\com\example\hellondk

这时我们能看到里面有 NdkJniUtils.class 的二进制文件。

  • 生成头文件
    打开cmd命令行,进入到 D:\HelloNdk\app\build\intermediates\classes\debug 目录下,使用以下命令生成 jni 头文件

javah -jni com.example.hellondk.NdkJniUtils

切记 javah -jni 后面跟着的时 包名.类名,形式如下:

javah -jni 包名.类名

此时在 D:\HelloNdk\app\build\intermediates\classes\debug 目录下便会生成 jni 头文件,这里的头文件目录如下:

D:\Projects\GitProjects\HelloNdk\app\build\intermediates\classes\debug\com_example_hellondk_NdkJniUtils.h

三、编写jni方法

在项目的 HelloNdk\app\src\main 下新建 jni 目录,用于放置 jni文件,此时将上面生成的头文件复制到此处,然后新建 hello.c 文件,然后 com_example_hellondk_NdkJniUtils.h 包含到 hello.c 文件中,并且实现 jni 方法,hello.c 代码如下:

#include "com_example_hellondk_NdkJniUtils.h"JNIEXPORT jstring JNICALL Java_com_example_hellondk_NdkJniUtils_getCLanguageString(JNIEnv * env, jobject obj){    return (*env)->NewStringUTF(env,"This just a test for Android Studio NDK JNI developer!");}

四、新建Android.mk文件

在jni目录下创建Android.mk文件,此文件主要是供nkd-build脚本找到要使用的 jni 代码和头文件,以及要生成的so文件放置在哪里,有兴趣的同学可以自己到android官网学习相关知识,在这里只要按照下面的写法来写即可, Android.mk 代码如下:

LOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_MODULE    := hello   #指定了生成的动态链接库的名字LOCAL_SRC_FILES := hello.c #指定了C的源文件叫什么名字include $(BUILD_SHARED_LIBRARY)  # 制定要生成动态链接库

使用命令行生成so文件

使用cmd进入jni目录:

D:\HelloNdk\app\src\main\jni

此时目录下应该有下面三个文件:

  • Android.mk
  • com_example_hellondk_NdkJniUtils.h
  • hello.c

然后使 ndk-build 命令即可生成 so 文件,生成文件目录如下:

D:\HelloNdk\app\src\main\obj

在android studio环境下使用 ndk-build 命令行形式生成so文件的步骤就结束了,说实话,此方法与eclipse中开发jni方法是一样的

Android studio开发 JNI 之CMAKE方式

此方法的大部分方法都与上面的方法一致,先按照命令行形式开发 JNI 所说执行:

  • 一、编写jni
  • 二、生成JNI方法头文件
  • 三、编写jni方法

然后必须要下载 cmake 以及 LLDB 两个工具(在sdk tools中)

使用 cmake ,需要在 module 下的 buidle.gradle 中添加以下语句,详情如下:

android {    compileSdkVersion 26    defaultConfig {        ···        // 使用Cmake工具        externalNativeBuild {            cmake {                cppFlags ""            }        }    }    buildTypes {        ···    }    // 配置CMakeLists.txt路径    externalNativeBuild {        cmake {            path "CMakeLists.txt"   // 设置所要编写的c源码位置,以及编译后so文件的名字        }    }}

CMakeLists.txt 文件(此文件要放在HelloNdk\app目录中,即 项目\module目录下)中的内容:

#cmake最小版本cmake_minimum_required(VERSION 3.4.1)add_library( # 设置so文件名称.             hello             # 设置这个so文件为共享.             SHARED             # 设置 c文件源码位置.             src/main/jni/hello.c )find_library( # Sets the name of the path variable.              log-lib              log )target_link_libraries( # 制定目标库.                       hello                       ${log-lib} )

这样就完成了所有的开发工作了,然后运行项目,即可在以下目录:

D:\HelloNdk\app\build\intermediates\cmake\debug\obj

中找到生成的so文件了。

示例代码下载地址:http://download.csdn.net/download/lzb19890920/10126432

Android studio开发 jni 简便方式(Android studio3.0以下可用)

Android Studio还有比较简便的开发方式,但是这种方式无法在Android studio 3.0及以上使用,因为已经被废弃了,如果使用的会报以下错误:

Error:Execution failed for task ':app:compileDebugNdk'.        > Error: Flag android.useDeprecatedNdk is no longer supported and will be removed in the next version of Android Studio.  Please switch to a supported build system.Consider using CMake or ndk-build integration. For more information, go to:https://d.android.com/r/studio-ui/add-native-code.html#ndkCompileTo get started, you can use the sample ndk-build script the Androidplugin generated for you at:D:\HelloNdk\app\build\intermediates\ndk\debug\Android.mkAlternatively, you can use the experimental plugin:https://developer.android.com/r/tools/experimental-plugin.htmlTo continue using the deprecated NDK compile for another 60 days, setandroid.deprecatedNdkCompileLease=1511184842395 in gradle.properties

这是因为在android studio3.0及以上采用cmake来编译生成so文件。

虽然方法被废弃了,但是还是有借鉴的意义。

此方法的大部分方法都与上面的方法一致,先按照命令行形式开发 JNI 所说执行:

  • 一、编写jni
  • 二、生成JNI方法头文件
  • 三、编写jni方法

然后在项目的根目录下的gradle.properties添加以下语句:

android.useDeprecatedNdk=true

然后在module下的 build.gradle 的 android代码块下的defaultConfig中添加语句 :

    ndk {            moduleName "hello"            ldLibs "log"        }

整个代码块如下:

android {    compileSdkVersion 26    defaultConfig {        applicationId "com.example.hellondk"        ···        ndk {            moduleName "hello"            ldLibs "log"        }    }}

如此便可直接生成so文件,文件位于:

D:\HelloNdk\app\build\intermediates\ndk\debug\obj

同时还可以在debug中看到Android.mk文件,这是因为android studio自动生成了此文件

更多相关文章

  1. android有了eventbus,一切与关界面通信问题迎刃而解。
  2. mac 平台下编译android版本 ffmpeg+h264
  3. CyanogenMod源码下载及在模拟器上刷机
  4. Android(安卓)WebView 与 原生的交互
  5. Android(安卓)四种异步操作UI界面的方法
  6. is 32-bit instead of 64-bit动态库错误分析
  7. Android项目清单文件
  8. Android(安卓)Root方法原理解析及Hook(四) GingerBreak
  9. Android在非UI线程中更新UI的方法

随机推荐

  1. android 读取网络在传输数据时的状态
  2. Android(安卓)service实例
  3. Android创建和配置布局动画
  4. Android 三星手机不能调起应用市场
  5. Android自定义对话框
  6. android SurfaceView 绘图
  7. Paint---PorterDuffXfermode
  8. adb获取activity信息
  9. Android(安卓)Volley自定义Request(JSON)
  10. (Android) Eclipse "launching delegate"