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

生成的so库存放路径.png

 

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

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

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


 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android Studio中引入第三方C++的步骤如下: 1. 将第三方的源代码放入项目的jni目录下,例如:`/app/src/main/jni/third_party_lib/`。 2. 在项目的`build.gradle`文件中添加以下代码: ```gradle android { // ... defaultConfig { // ... externalNativeBuild { cmake { cppFlags "-std=c++11 -frtti -fexceptions" abiFilters 'armeabi-v7a', 'arm64-v8a', 'x86', 'x86_64' } } } // ... } // ... externalNativeBuild { cmake { path "CMakeLists.txt" } } ``` 其中,`path`指定了CMakeLists.txt文件的路径,`cppFlags`指定了编译选项,`abiFilters`指定了支持的CPU架构。 3. 在项目的`CMakeLists.txt`文件中添加以下代码: ```cmake add_library(third_party_lib SHARED IMPORTED) set_target_properties(third_party_lib PROPERTIES IMPORTED_LOCATION ${CMAKE_CURRENT_SOURCE_DIR}/third_party_lib/libthird_party_lib.so) include_directories(${CMAKE_CURRENT_SOURCE_DIR}/third_party_lib/include) ``` 其中,`add_library`指定了的名称,`IMPORTED`表示这是一个外部,`IMPORTED_LOCATION`指定了文件的路径,`include_directories`指定了头文件的路径。 4. 在JNI代码中调用第三方的函数。 ```c++ #include "third_party_lib/include/third_party_lib.h" extern "C" JNIEXPORT jstring JNICALL Java_com_example_myapplication_MainActivity_callThirdPartyLib(JNIEnv* env, jobject /* this */) { ThirdPartyLib thirdPartyLib; std::string result = thirdPartyLib.doSomething(); return env->NewStringUTF(result.c_str()); } ``` 其中,`third_party_lib/include/third_party_lib.h`是第三方的头文件,`ThirdPartyLib`是第三方的类,`doSomething`是第三方的函数。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值