Android Studio 加载第三方C/C++库

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,编译完成后,我们就可以得到我们需要的库。

Android Studio 加载第三方C/C++库_第1张图片

生成的so库存放路径.png

 

我们可以把obj目录下的文件夹和文件一起拷贝出来给其他工程使用。

4 C/C++混合编程需要注意的事项

  • 当我们在C++的源码文件中直接调用C源码中的方法,编译过程中会报无法发现C方法的问题,导致链接失败。
  • 我们需要在C++源码或包含的C源码头文件中将需要调用的C方法声明用 extern "C" { C方法声明列表 } 或者我们可以在C++源码中使用 extern "C" {include "c源码头文件"}的方式。


 

你可能感兴趣的:(C++/C)