1 修改app目录下的CMakeLists.tx
- 添加目标库
add_library( # Sets the name of the library.
native-lib
# Sets the library as a shared library.
SHARED
# Provides a relative path to your source file(s).
src/main/cpp/native-lib.cpp ) # 依赖的源码文件
- 设置依赖头文件路径
include_directories(src/main/cpp)
- 导入第三方库
add_library(
hello-lib #需要导入第三方库的别名,自定义。
SHARED #动态库
IMPORTED) #因为库已经存在所以使用导入
- 设置第三库的所在路径
set_target_properties( # Specifies the target library.
hello-lib
# Specifies the parameter you want to define.
PROPERTIES IMPORTED_LOCATION
# Provides the path to the library you want to import.
# /${ANDROID_ABI}表示处理器架构 第三方库必须存放在这类路径下
#如果有第三方库不支持或目标不需要支持的处理器架构,需要在app目录下的
#build.gradle文件中进行配置
#路径一定要设置正确,不然会报依赖错误
${CMAKE_SOURCE_DIR}/src/main/jniLibs/${ANDROID_ABI}/libpsamcard.so )
- 将第三方库与目标库进行关联
target_link_libraries( # Specifies the target library.
native-lib
# Links the target library to the log library
# included in the NDK.
hello-lib
${log-lib} )
2修改app目录下的build.gradle
- 安卓系统支持系统结构有好几种,所以在使用Android Studio生成SO库时,如果不加指定说明,那么将默认生成几种架构下的so库,如果依赖的第三方库缺少某个架构的so库,编译器就会报错。所以我们希望生成的目标架构的so库必须是第三方库包含的。如果不包含,就需要对编译规则进行设置。
- app的gradle的defaultConfig里面加上
ndk {
abiFilters "armeabi" // 指定要ndk需要兼容的架构(这样其他依赖包里mips,x86,"armeabi-v7a",arm-v8之类的so会被过滤掉)
}
如此我们编译链接生成的so库就只包含armeabi架构的,而其他架构的则不包含。
3编译生成目标库
- 点击工具栏中的Build选择Make Project,编译完成后,我们就可以得到我们需要的库。
生成的so库存放路径.png
我们可以把obj目录下的文件夹和文件一起拷贝出来给其他工程使用。
4 C/C++混合编程需要注意的事项
- 当我们在C++的源码文件中直接调用C源码中的方法,编译过程中会报无法发现C方法的问题,导致链接失败。
- 我们需要在C++源码或包含的C源码头文件中将需要调用的C方法声明用 extern "C" { C方法声明列表 } 或者我们可以在C++源码中使用 extern "C" {include "c源码头文件"}的方式。