Android 设置动态库依赖路径

在 Android 中,使用 dlopen 打开动态库时,可以通过以下方法设置动态库的依赖路径

LD_LIBRARY_PATH

在调用 dlopen 之前,使用 setenv 设置 LD_LIBRARY_PATH 环境变量

#include <jni.h>
#include <cstdlib> // For setenv
#include <dlfcn.h> // For dlopen

extern "C" JNIEXPORT void JNICALL
Java_com_example_myapp_MainActivity_loadLibrary(JNIEnv *env, jobject /* this */) {
    //将 LD_LIBRARY_PATH 设置为包含你的动态库的路径。1 表示如果环境变量已存在,则覆盖它
    setenv("LD_LIBRARY_PATH", "/path/to/your/libs", 1);

    // 打开动态库
    void* handle = dlopen("libmylibrary.so", RTLD_NOW);
    if (!handle) {
        // 处理错误
        const char* error = dlerror();
        // 打印或处理错误信息
    }

    // 关闭动态库
    dlclose(handle);
}

link_directories和target_link_directories

link_directories 和 target_link_directories 是两个不同的命令,用于设置库的搜索路径

link_directories

link_directories 用于添加目录到链接器的搜索路径。这意味着链接器在链接时会在这些目录中查找库文件

cmake_minimum_required(VERSION 3.10)
project(MyProject)

# 添加库的搜索路径
link_directories(/path/to/your/libs)

add_executable(my_executable main.cpp)
target_link_libraries(my_executable mylibrary)

link_directories 会影响所有后续的目标(target),而不仅仅是某一个特定的目标

target_link_directories

target_link_directories 是 CMake 3.13 引入的新命令,允许你为特定的目标设置库的搜索路径。这提供了更细粒度的控制,使你可以指定特定目标的链接库目录,而不影响其他目标

cmake_minimum_required(VERSION 3.10)
project(MyProject)

add_executable(my_executable main.cpp)

# 为特定目标设置库的搜索路径
target_link_directories(my_executable PRIVATE /path/to/your/libs)

target_link_libraries(my_executable mylibrary)
  • PRIVATE 表示库路径仅对目标自身有效
  • PUBLIC 表示库路径对目标自身和其依赖目标有效
  • INTERFACE 表示库路径仅对依赖该目标的其他目标有效。
  1. link_directories: 使用这种方法时,所有后续的目标都可以看到添加的库路径。这种方法简单,但可能会导致不必要的路径冲突,特别是在大型项目中
  2. target_link_directories: 推荐在较新版本的 CMake 中使用,它提供了更好的封装性和灵活性。你可以为不同的目标设置不同的库路径,避免路径冲突,并且提高了构建脚本的可维护性
  • 6
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值