Android Studio 编译C/C++生成.so文件

前期准备:下载NDK、CMake

方法一:使用AndroidStudio自动创建Native C/C++ 项目
  1. 创建新项目

创建项目后,会默认生成两个文件和相关默认配置.

  1. 若创建好C++项目后报错,则需要配置一下NDK路径

如果上图配置页面显示无法配置,则需要在local.properties中手动配置NDK。

3.点击 Build -> Make Project,编译完成后,可以在编译好后的build目录下查看生成的“.so”文件。

方法二:ndk-build 编译C生成.so文件

1. 创建一个Java类并添加本地方法

public class NDKStudyTools{
    //创建一个native 方法
    public native static StringstringFromJIN();
}

2. 点击:Build -> make Project编译项目

3. 构建好后,buid 目录下会生成NDKStudyTools.class 文件(不同as 版本对应的详细目录会有不同,不过都在build 目录下,找下就有)

4. 创建C++ .h 头文件

(1)打开Android Studio -> Terminal ,使用命令进入到项目main目录:cd app\src\main

    (2)使用命令创建 .h 的头文件(如果提示“找不到 javah 命令”,需要配置下jdk的环境变量)

javah -d jni -classpath ...\classes com.junker.study.c.yagain.NDKStudyTools.class
命令字段介绍:
javah:生成头文件
-d jni:在当前定位到的目录下创建一个 jni 文件夹
-classpath ...\classes 指定要生成头文件的字节码文件目录,即生成的 com.junker.study.c.yagain.NDKStudyTools.class 字节码目录
注意:这个 classes 文件目录可能太长,输入麻烦,我们可以找到 debug 文件夹,右键 copy path,复制文件目录即

       (3)回车之后,会在mian目录下创建一个jni文件夹并生成一个 "xxx.h"的头文件(头文件命名也是按照包名加字节码名的规范,以下划线连接)

5. 在jni目录下创建一个 .c 文件并实现com_junker_study_c_yagain_NDKStudyTools.h 头文件中的本地方法

6. jni 目录下创建 .mk 文件

(1)创建 Android.mk 文件并添加配置(注意:不要在文件中添加注释字符,使用 ndk-build 命令编译时会报错)。

LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE:=app
LOCAL_SRC_FILES:=ndk_test.c
include $(BUILD_SHARED_LIBRARY)

参数说明:(注:以下不用拷贝到文件中,此处只做说明)
LOCAL_PATH := $(call my-dir):
设置工作目录,它用于在开发tree中查找源文件。宏my-dir由Build System提供,会返回Android.mk文件所在的目录
include $(CLEAR_VARS):
CLEAR_VARS变量由Build System提供。指向一个指定的GNU Makefile,由它负责清理LOCAL_xxx类型文件,但不是清理LOCAL_PATH,所有的编译控制文件由同一个GNU Make解析和执行,其变量是全局的。所以清理后才能便面相互影响,这一操作必须有。
LOCAL_MODULE:=app:
模块必须定义,以表示Android.mk中的每一个模块,名字必须唯一且不包含空格,Build System会自动添加适当的前缀和后缀。例如,demo,要生成动态库,则生成libdemo.so。但请注意:如果模块名字被定义为libabd,则生成libabc.so。不再添加前缀。
LOCAL_SRC_FILES := ndk_test.c:
指定参与模块编译的C/C++源文件名。不必列出头文件,build System会自动帮我们找出依赖文件。缺省的C++源码的扩展名为.cpp。
include $(BUILD_SHARED_LIBRARY):
BUILD_SHARED_LIBRARY是Build System提供的一个变量,指向一个GUN Makefile Script。它负责收集自从上次调用include $(CLEAR_VARS)后的所有LOCAL_xxxxinx。并决定编译什么类型
1. BUILD_STATIC_LIBRARY:编译为静态库
2. BUILD_SHARED_LIBRARY:编译为动态库
3. BUILD_EXECUTABLE:编译为Native C可执行程序
4. BUILD_PREBUILT:该模块已经预先编译

(2)创建 Application.mk 文件并添加配置(注意:不要在文件中添加注释字符,使用 ndk-build 命令编译时会报错)。

APP_ABI := all

参数说明:(注:以下不用拷贝到文件中,此处只做说明)
APP_ABI := all
默认生成支持的多种类型.so

示例图:

7. 生成so库

(1) 使用 Terminal 命令进入到项目jni目录:cd app\src\main\jni

(2)使用 ndk-build 命令生成 so 库( 如果提示没有,需要配置下ndk的环境变量)

8、使用so库

(1)为了能加载 app.so 库,需要在主module下的 build.gradle 文件夹的 android 下添加如下代码:

sourceSets{
    main() {
        jniLibs.srcDirs =['src/main/libs']
        jni.srcDirs =[] //disable automatic ndk-build call, which ignore our Android.mk
    }
}

(2)在 NDKStudyTools.java 中加载 so 库(注:库名称不需要写 libapp,只用写 app,也就是去掉lib前缀)

public class NDKStudyTools{
    // 动态导入 so 库
    static {
        System.loadLibrary("app");
    }
    //创建一个native 方法
    public native static StringstringFromJIN();
}

(3)验证使用,跑一跑run

  • 5
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Android Studio 可以通过 JNI(Java Native Interface)来调用 C/C++ 文件。 具体步骤如下: 1. 在 Android Studio 项目下,创建一个名为 `jni` 的目录。 2. 在 `jni` 目录下,创建一个名为 `native-lib.c` 的 C 文件。 3. 在 `native-lib.c` 文件中实现需要调用的 C/C++ 函数。 4. 在 `jni` 目录下创建一个名为 `Android.mk` 的文件,用于编译 `native-lib.c`。 ``` LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := native-lib LOCAL_SRC_FILES := native-lib.c include $(BUILD_SHARED_LIBRARY) ``` 5. 在 `jni` 目录下创建一个名为 `Application.mk` 的文件,用于指定编译选项。 ``` APP_ABI := all ``` 6. 在 `MainActivity.java` 文件中,声明需要调用的 C/C++ 函数。 ``` public native int add(int a, int b); ``` 7. 在 `MainActivity.java` 文件的 `onCreate` 方法中,加载动态库,并调用 C/C++ 函数。 ``` static { System.loadLibrary("native-lib"); } int result = add(1, 2); ``` 8. 使用 `ndk-build` 命令编译动态库,并将编译生成的 `.so` 文件放置到 `app/src/main/jniLibs` 目录下。 9. 运行 Android 应用程序,即可调用 C/C++ 函数。 注意事项: 1. 需要在 `build.gradle` 文件中添加如下配置: ``` android { defaultConfig { ndk { abiFilters 'armeabi-v7a', 'x86' } } sourceSets { main { jniLibs.srcDirs = ['src/main/jniLibs'] } } } ``` 2. 需要安装 NDK 工具包,并在 `local.properties` 文件中指定 NDK 路径。 ``` ndk.dir=/path/to/ndk ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值