利用android studio 生成 JNI需要的动态库so文件 图文详解
利用android studio 生成 JNI需要的动态库so文件 图文详解
一、环境搭建
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的下载地址:
更多推荐
所有评论(0)