在 Android 中,使用 dlopen 打开动态库时,可以通过以下方法设置动态库的依赖路径
LD_LIBRARY_PATH
在调用 dlopen 之前,使用 setenv 设置 LD_LIBRARY_PATH 环境变量
cpp
#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 用于添加目录到链接器的搜索路径。这意味着链接器在链接时会在这些目录中查找库文件
cpp
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 引入的新命令,允许你为特定的目标设置库的搜索路径。这提供了更细粒度的控制,使你可以指定特定目标的链接库目录,而不影响其他目标
cpp
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 表示库路径仅对依赖该目标的其他目标有效。
- link_directories: 使用这种方法时,所有后续的目标都可以看到添加的库路径。这种方法简单,但可能会导致不必要的路径冲突,特别是在大型项目中
- target_link_directories: 推荐在较新版本的 CMake 中使用,它提供了更好的封装性和灵活性。你可以为不同的目标设置不同的库路径,避免路径冲突,并且提高了构建脚本的可维护性