动态库查找路径设置

一直在用 LD_LIBRARY_PATH 设置动态苦查找路径在开发时使用。今天设置后不起作用,想了半天才想起来需要 export。记此一笔:

 

[sh]# export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:`pwd`

使用VS2015编译和调用动态链接库dll 1. 首先建工程,选择dll,记得勾上“导出符号” 后面不用自己搞那些宏定义会省事很多。 建立工程myDll,记得勾上“导出符号” 类型选择dll 2. IDE自动生成的代码已经把整个架构弄好了,其中和项目同名的.h和.cpp文件就是我们自己写代码的地方了。我想写的dll是导出一个类,在这里我就直接在它自动生成的CmyDll类上面改了。 myDll.h myDll.cpp 在mydll.h和mydll.cpp中给类添加成员函数 //mydll.h class MYDLL_API CmyDll { public: CmyDll(void); // TODO: 在此添加您的方法。 int myFunction(int a, int b); }; //mydll.cpp int CmyDll::myFunction(int a, int b) { return a*b; } 3.编译的时候我选择了release,这里可以用默认的debug也行 在mydll.h和mydll.cpp中给类添加成员函数 最后生成解决方案后产生的mydll.lib和mydll.dll就是我们需要的二进制文件了。lib文件是编译是要用的,而dll是调用这个库的程序运行时需要的。 调用dll 1.重新建立一个工程 这回选择普通的控制台程序就行了。我建了个名为myDllCall的工程。 2.把库的头文件include进来,以及连接lib文件 其中 include进来的 myDll.h 和 **#pragma comment()**的lib根据自己的路径写。 #include "stdafx.h" #include "../../myDll/myDll/myDll.h" //头文件 #pragma comment(lib,"../../myDll/Release/myDll.lib") //调用自己写的外部库 #include int main() { CmyDll mydll; int a, b; std::cin >> a >> b; std::cout << mydll.myFunction(a, b) <> a >> b; std::cout << mydll.myFunction(a, b) << std::endl; return 0; } 3.dll放到可执行文件同一目录下面 刚刚的代码直接编译没问题,运行会报错. 直接编译没问题,运行会报错 原因是dll要和生成的可执行文件在同一个目录下,我把mydll.dll放进去之后就解决了。 我们成功的在自己的工程里调用了外部的类 可以看到我们成功的在自己的工程里调用了外部的类。
### 如何在 CMake 中指定动态库查找路径 在 CMake 中,可以通过多种方式来配置动态库查找路径。以下是几种常用的方法及其具体实现: #### 使用 `CMAKE_PREFIX_PATH` 设置库的根目录 通过设置 `CMAKE_PREFIX_PATH` 变量,可以告诉 CMake 去哪些地方寻找依赖项。这通常用于简化第三方库的定位过程[^1]。 ```cmake set(CMAKE_PREFIX_PATH "/path/to/your/library;/another/path") find_package(SomeLibrary REQUIRED) target_link_libraries(your_target PRIVATE SomeLibrary::SomeLibrary) ``` 此方法适用于那些遵循标准安装布局(如 `include`, `lib` 子目录)的库。 --- #### 配置运行时库路径 (`RPATH`) 如果目标是在程序运行时让可执行文件找到所需的共享库,则需要调整 `RPATH`。这是通过修改 `CMAKE_INSTALL_RPATH` 或者直接操作构建目标的属性完成的[^2]。 ```cmake # 添加自定义 RPATH 到构建的目标 set(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_PREFIX}/lib;${ADDITIONAL_LIBRARY_PATH}") # 如果希望仅影响特定目标而不是全局范围 set_target_properties(your_executable PROPERTIES BUILD_WITH_INSTALL_RPATH TRUE) set_target_properties(your_executable PROPERTIES INSTALL_RPATH "${CMAKE_INSTALL_PREFIX}/lib") ``` 这种方法特别适合于复杂的多模块项目,其中不同部分可能位于不同的子目录下。 --- #### 显式声明库位置 (使用 `link_directories`) 当某些库未被自动检测到或者其所在的位置不常见时,可以直接调用 `link_directories()` 来手动添加额外的搜索路径[^3]。 ```cmake link_directories("/custom/lib/directory") add_executable(example example.cpp) # Link against the libraries found within /custom/lib/directory target_link_libraries(example custom_library_name) ``` 注意这种方式虽然简单明了,但在现代 CMake 实践中并不推荐频繁使用,因为它可能会降低项目的移植性和灵活性。 --- #### 结合 VCPKG 工具链文件管理依赖关系 对于采用 vcpkg 管理外部依赖的情况,只需引入对应的工具链文件即可自动化处理大部分环境变量设定工作。 ```cmake set(CMAKE_TOOLCHAIN_FILE "vcpkg_root_path/scripts/buildsystems/vcpkg.cmake" CACHE STRING "") find_package(OpenCV REQUIRED) target_link_libraries(my_target PRIVATE OpenCV::OpenCV) ``` 这样不仅减少了人为干预的可能性,还提高了跨平台支持的能力。 --- ### 总结 以上介绍了四种主要途径帮助开发者更高效地控制 cmake 下动态链接库的行为模式。每种方案都有各自适用场景以及优缺点,在实际开发过程中应依据具体情况灵活选用最合适的策略组合起来解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值