ndk笔记:androidstudio使用ndk

注释:此笔记针对使用cmd方式来创建.h文件,全程都是手动操作。为了能深入里面新建和调用so库的完成流程
环境配置:
在项目根目录的local.properties中加入nkd的路径

Paste_Image.png

第一步:新建一个java文件,此文件最好不要继承各种Activity(原因后面解释)。

public class NativeUtils {
    public static  native String getString();//调用C语言的方法
}

第二步:生成头文件(.h文件)

  1. 上面的新建的java文件我们要生成一个class文件,通过过Build下面的Rebuild Project ,可以生成字节码class文件。这个字节码码文件存放在当前这个项目的app文件夹里面。\build\intermediates\classes\debug +包名下。

![Uploading Paste_Image_636227.png . . .]
要通过这个class文件生成响应的头文件。

  1. 打开as左下角的Teminal,然后输入 cd app\src\main。
    生成头文件的指令:
javah -d jni -classpath ..\..\build\intermediates\classes\debug  com.zhou.ndk3.NativeUtils

指令结束后会在jni目录下生成一个后缀名为.h的文件,文件名字就是com_zhou_ndk3_NativeUtils.h。其实就是报名和类型的组合。

.h文件内容:

/* DO NOT EDIT THIS FILE - it is machine generated */
#include 
/* Header for class com_zhou_ndk3_NativeUtils */

#ifndef _Included_com_zhou_ndk3_NativeUtils
#define _Included_com_zhou_ndk3_NativeUtils
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     com_zhou_ndk3_NativeUtils
 * Method:    getString
 * Signature: ()Ljava/lang/String;
 */
JNIEXPORT jstring JNICALL Java_com_zhou_ndk3_NativeUtils_getString
  (JNIEnv *, jclass);

#ifdef __cplusplus
}
#endif
#endif

.h的文件内容不要手动修改。
Java_com_zhou_ndk3_NativeUtils_getString这个就是方法名字,getString对应的就是我们在最初新建java文件NativeUtils 中的getString方法。java代码就是通过.h文件中的这个方法和c进行交互。

指令解析:
-classpath:NativeUtils对应的字节码存放的路径
如果当前类(编写了原生方法的类)是集成了AppCompatActivity,这个类是存放在v7包中的。所以要在class
path中加入v7包的路径。指令就变成

 javah -d jni -classpath            E:\android_sdk\androidstudio_sdk\sdk\extras\android\m2repository\com\android\support\appcompat-v7\25.1.0\appcompat-v7-25.1.0-sources.jar;..\..\build\intermediates\classes\deb
ug com.zhou.ndk3.MainActivity

javah -d jni:把生成的.h头文件存放到jni目录中

第三部:配置文件

1.在build.gradle的defaultConfig中加入ndk生成的so名字:

ndk{
            moduleName "rilegou"
        }

2.在项目的根目录下的gradle.properties中加入

android.useDeprecatedNdk=true

意思是使用ndk-build的方式去打包编译,c文件。Androidstudio新版本中使用的是cmake。如果不指定这个编译会报错。因为编译器不知道用哪一种方式去编译c文件。

3.在jni目录下新建Android.mk和Application.mk。
Android.mk中的内容:

LOCAL_MODULE    := rilegou 
LOCAL_SRC_FILES := test.c
LOCAL_DEFAULT_CPP_EXTENSION := cpp
include $(BUILD_SHARED_LIBRARY)

解析:
LOCAL_MODULE :编译出来的so库的文件名字。这个名字会被默认加上lib。最终so的名字就为:librilegou.so。调用的时候就只要写:rilegou 。并且这个名字要和build.gradle中的moduleName 相同
LOCAL_SRC_FILES :被编译的.c文件

Application.mk中的内容:

APP_ABI := all

解析:
APP_ABI :编译打包出来支持的各种cpu;
all:支持各种类型

ndk笔记:androidstudio使用ndk_第1张图片
Paste_Image.png

需要支持那种类型,就把all改变成希望支持的那种平台。例如 x86 x86_64 armeabi

4.编写c文件。
在jni目录下创建test.c文件夹。这个文件的名字要和Android.mk中的LOCAL_SRC_FILES 的名字相同。
test.c文件内容:

#include 
JNIEXPORT jstring JNICALL Java_com_zhou_ndk3_NativeUtils_getString(JNIEnv * env, jobject jObj){
        jstring str = (*env)->NewStringUTF(env, "HelloWorld from JNI !");
        return str;
}

include 就是把.h文件引入。当java调用getString()方法时,就会触发这个.c文件中的代码。

最后我们运行 Build->Rebuild Project,就可以生成so文件了。so文件在build文件夹下面能看到

ndk笔记:androidstudio使用ndk_第2张图片
Paste_Image.png

项目地址:
https://github.com/lvdouzhou/as_ndk.git

你可能感兴趣的:(ndk笔记:androidstudio使用ndk)