动态库查找路径设置

一直在用 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放进去之后就解决了。 我们成功的在自己的工程里调用了外部的类 可以看到我们成功的在自己的工程里调用了外部的类。
### 查看Linux系统中的动态库搜索路径 在 Linux 系统中,动态链接器解析 `.so` 文件时会按照特定顺序查找共享库文件。以下是查看动态库搜索路径以及确认 `ldconfig` 配置后动态链接器解析 `.so` 文件顺序的方法。 #### 1. 查看动态库搜索路径 可以通过以下方法查看系统的动态库搜索路径- **检查 `/etc/ld.so.conf` 文件及其引用的配置文件**:该文件中定义了动态库的搜索路径,每个路径占一行[^1]。 - **查看环境变量 `LD_LIBRARY_PATH`**:如果设置了该变量,则动态链接器会优先从其指定的路径查找共享库[^2]。 - **使用 `ldconfig -p` 命令**:该命令会列出当前系统中所有已知的共享库及其路径,这些信息来源于 `/etc/ld.so.cache` 文件[^3]。 示例命令: ```bash cat /etc/ld.so.conf echo $LD_LIBRARY_PATH ldconfig -p ``` #### 2. 动态链接器解析 `.so` 文件的顺序 动态链接器在解析 `.so` 文件时遵循以下优先级顺序[^2]: - **环境变量 `LD_LIBRARY_PATH` 指定的路径**:如果设置了该变量,则动态链接器会优先从其指定的路径查找共享库。 - **`/etc/ld.so.cache` 文件中记录的路径**:这是由 `ldconfig` 命令生成的缓存文件,包含系统中所有已知共享库的位置[^1]。 - **默认路径**:如果没有找到匹配的共享库,动态链接器会检查默认路径,通常是 `/lib` 和 `/usr/lib`。 #### 3. 确认 `ldconfig` 配置后动态库的调用优先级 执行 `ldconfig` 后,动态链接器会优先加载 `/etc/ld.so.conf` 及其引用配置文件中定义的路径下的共享库。例如,如果 `/etc/ld.so.conf.d/orion-camera.conf` 包含路径 `/usr/lib/orion-camera`,则该路径中的共享库会被优先考虑,前提是它们出现在默认路径(如 `/usr/lib` 或 `/lib`)之前[^5]。 验证方法: - 使用 `ldd` 命令检查程序依赖的共享库及其路径: ```bash ldd /path/to/executable ``` - 输出结果会显示每个共享库的实际路径,从而确认动态链接器是否正确解析了配置后的路径--- ### 示例代码 以下是一个简单的 C 程序,用于演示动态链接库的加载过程: ```c #include <stdio.h> int main() { printf("Dynamic library loaded successfully.\n"); return 0; } ``` 编译并链接共享库时,确保指定正确的路径: ```bash gcc -o test_program test_program.c -L/usr/lib/orion-camera -lorion ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值