iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >利用android studio 生成 JNI需要的动态库so文件 图文详解
  • 770
分享到

利用android studio 生成 JNI需要的动态库so文件 图文详解

ndk-buildcmakejnindkso库文件 2023-09-12 12:09:30 770人浏览 薄情痞子
摘要

一、环境搭建 1.1 Android studio2021.2.1安装 到官网下载,此处不再陈述 1.2 JNI安装 JNI 是jdk里的内容,电脑上正确安装并配置JDK即可。 1.3 NDK安装 直接在Android studio下载(F

一、环境搭建

1.1 Android studio2021.2.1安装

到官网下载,此处不再陈述

1.2 JNI安装

JNI 是jdk里的内容,电脑上正确安装并配置JDK即可。

1.3 NDK安装

直接在Android studio下载(File---->Settings)

1.4 编译工具

工具一:AndroidStudio下载安装cmake(调试Native时会使用到LLDB,请一同勾选下载安装)

工具二:用NDK的脚本工具使用ndk-build

二、Native c++项目

2.1 创建项目

新建项目,选择Native C++,如下图所示:

2. 2 创建项目后默认的示例代码

 新建的项目,默认有完整的native示例代码、cmake的配置

如下所示:

(1)jave代码

(2)c++代码

(3)cmake的配置文件CMakeLists

(4) 在app目录下的build.gradle配置

 (5)编译后生成的so文件路径

(6)运行安装apk的页面显示c++方法里面的内容

三、cmake的应用

创建一个Native C++项目继续一下操作。

 3.1 NDK环境检查(以win10为例)

(1)给NDK配置环境变量。

找到NDK在本地的路径

 把路径配置到环境变量中

 (2)给项目配置NDK

File --> Project Structure --> SDK Location,如下图所示 

注意:若选择不了NDK路径,直接在local.properties设置NDK路径,效果是一样的

 3.2 C/C++功能实现

在创建工程后,默认有个写C++代码文件native-lib.cpp,在此文件中写的C++方法可在java中调用,整个效果如上面的“二  ——> (6)”

3.3 cmake指定输出so库文件的输出路径

(1)在CMakeLists.txt文件中配置文件的输出路径

# 配置库生成路径# CMAKE_CURRENT_SOURCE_DIR是指 cmake库的源路径,通常是build/.../cmake/# /../jniLibs/是指与CMakeList.txt所在目录的同级目录:jniLibs (如果没有会新建)# ANDROID_ABI 生成库文件时,采用gradle配置的ABI策略(即:生成哪些平台对应的库文件)set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/../jniLibs/${ANDROID_ABI})

(2)在app的build.gradle中配置

sourceSets {        main {            jniLibs.srcDirs = ['jniLibs']//指定lib库目录        }    }

(3)点击状态栏的Build ——> Rebuild Project

(4) 查看so库文件的输出结果

 注意:在CMakeLists.txt文件中配置文件的输出路径配置了CMAKE_CURRENT_SOURCE_DIR,并非表示编译时直接将so生成在该目录中,实际编译时,so文件仍然是 先生成在build/.../cmake/中,然后再拷贝到目标目录中的。

3.4 生成指定CPU平台对应的so库文件

在app下的build.gradle文件下配置,两种方式都可行,配置后Rebuild Project看最终的运行结果。如:我只想仅生成CPU是arm64-v8a的so文件。

方式1:cmake中设置abiFilters 

abiFilters "arm64-v8a"

方式二: 在ndk中设置abiFilters

ndk {    abiFilters "arm64-v8a"}

 四、ndk-build的应用

创建一个Native C++项目,项目名称为jniNdkBuild继续以下操作

4.1 检查是否配置了NDK配置环境变量

打开一个cmd窗口,输入命令"ndk-build",出现下图所示,则表示ndk环境变量配置成功

未配置的可参照上面的“三  3.1”

4.2 C/C++功能的实现

(1)在app的main目录下,新建与cpp同级的文件夹jni

(2)拷贝 cpp文件夹下的C++代码文件native-lib.cpp到jni文件下,并重新命名为ndkbuild.cpp,主要是为了跟cmake区分开库文件名称,在MainActivity类中,需要把加载的库名改成ndkbuild

 (3)调整ndkbuild.cpp实现方法的文本为“Hello!  I am from C++ ndk-build”,主要是为了与cmake的内容区分开。

 (4)在jni目录下新建Android.mk文件,并配置以下内容

#表示Android.mk所在目录LOCAL_PATH := $(call my-dir)#设置库文件的输入目录#输出目录 ../jniLibs/#源目录 $(TARGET_ARCH_ABI)NDK_APP_DST_DIR=../jniLibs/$(TARGET_ARCH_ABI)#CLEAR_VARS变量指向特殊 GNU Makefile,用于清除部分LOCAL_变量include $(CLEAR_VARS)#模块名称LOCAL_MODULE    := ndkbuild#构建系统用于生成模块的源文件列表LOCAL_SRC_FILES := ndkbuild.cpp#BUILD_SHARED_LIBRARY 表示.so动态库#BUILD_STATIC_LIBRARY 表示.a静态库include $(BUILD_SHARED_LIBRARY)

 (5)在app目录下,build.gradle的配置,配置完成后rebuild Project,即可生成对应库文件

在android里面配置

//定义ndkBuild默认配置属性externalNativeBuild {    ndkBuild {        cppFlags ""    } }
//定义ndkBuild对应的Android.mk路径(重要)externalNativeBuild {    ndkBuild{        path file("src/main/jni/Android.mk")    }}

配置后如下图所示:

(6)重新编译(Rebuild Project),查看so库文件的输出效果

 4.3 生成指定CPU平台对应的so库文件

配置指定CPU类型输出so库文件,可有两种方式实现。例如:我只想生成arm64-v8a。

注意:由于创建的项目默认是cmake配置,需把cmake的配置删除,换成ndkbuild

方式一:ndkBuild 中设置abiFilters

//定义ndkBuild默认配置属性externalNativeBuild {    ndkBuild {        cppFlags ""        abiFilters "arm64-v8a"    }}

方式二: 在ndk中设置abiFilters

ndk {    // 生成指定CPU平台对应的so库文件    abiFilters "arm64-v8a" }

 4.4 查看项目运行安装apk页面

(1)用ndkbuild编译方式,则cmake相关文件可以删除

 (2)运行安装apk,页面显示native的文本如下图所示:

注意:如果直接在AS的Terminal或则cmd窗口执行了ndk-build命令,则不执行gradle的配置,只会根据Android.mk进行编译,编译生成的CPU的so库文件是包括所有平台的。此文章不再演示用命令生成so库文件,感兴趣的可自行百度。

以上demo的下载地址:

https://download.csdn.net/download/zaq977684/87791268

来源地址:https://blog.csdn.net/zaq977684/article/details/130684559

--结束END--

本文标题: 利用android studio 生成 JNI需要的动态库so文件 图文详解

本文链接: https://www.lsjlt.com/news/404503.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作