Linux程序运行时加载动态库失败的解决方法

Linux下不能加载动态库问题

当出现下边异常情况

./test: error while loading shared libraries: libxxx.so: cannot open shared object file: No such file or directory

原因:

  1. 系统并无此文件
  2. 操作系统的中LD_LIBRARY_PATH环境变量没有包含该共享库(lib*.so.* 文件)
  3. 共享库版本不对

第一、三类问题只能通过重新下载安装解决。

第二类问题解决办法如下。

系统路径并包含指定动态库的解决办法

方法一:在终端输入

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:${MyLibPath}

方法二:修改~/.bashrc文件

在文件末尾添加

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:${MyLibPath}

在终端执行source ~/.bashrc 使配置文件生效

方法三:修改/etc/profile文件

export MPI_HOME=/usr/cluster 
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:${MyLibPath}

在终端执行source /etc/profile 使配置文件生效

方法四:修改/etc/ld.so.conf文件

/etc/ld.so.conf文件中添加路径,vi /etc/ld.so.conf

添加下边内容

include ld.so.conf.d/*.conf
${MyLibPath}

延伸阅读

ldconfig

类unix系统默认的共享库搜索目录为 /usr/lib/usr/local/lib 目录。

ldconfig命令的用途, 主要是在默认搜寻目录(/usr/lib/usr/local/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下, 搜索出可共享的动态链接库(格式如lib*.so*), 进而创建出动态装入程序(ld.so)所需的连接和缓存文件. 缓存文件默认为/etc/ld.so.cache, 此文件保存已排好序的动态链接库名字列表.

如果共享库文件安装到了 /usr/local/lib (一般开源的共享库都会安装到该目录下)或者其它非 /lib 或 /usr/lib 目录下,那么在执行 ldconfig 命令前,还要把新的共享库目录加入到共享库配置文件 /etc/ld.so.conf 中,如下:

cat /etc/ld.so.conf
# 输出 include ld.so.conf.d/*.conf
echo "$MyLibPath" >> /etc/ld.so.conf  # 添加指定库目录
ldconfig

或者在 /etc/ld.so.conf.d/ 目录下新建任何以 .conf 为后缀的文件,在该文件中加入库文件所在的目录。然后执行 ldconfig 更新 /etc/ld.so.cache 文件。

LD_LIBRARY_PATH

如果共享库文件安装到了其他非 /usr/lib/usr/local/lib 目录下,但是又不想在 /etc/ld.so.conf 文件中加共享库路径(或者是没有权限加路径)。那可以 export 一个全局变量 LD_LIBRARY_PATH,然后运行程序的时候就会去找个目录中找共享库。

LD_LIBRARY_PATH的意思是告诉loader在哪些目录中可以找到共享库. 可以设置多个搜索目录, 这些目录之间用冒号分隔开. 比如安装了一个mysql到/usr/local/mysql目录下, 其中有一大堆库文件在/usr/local/mysql/lib下面, 则可以在.bashrc或.bash_profile或shell里加入以下语句即可:

export LD_LIBRARY_PATH=/usr/local/mysql/lib:$LD_LIBRARY_PATH   

一般来讲这只是一种临时的解决方案, 在没有权限或临时需要的时候使用.

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C++中,动态库(也称为共享库或DLL)崩溃通常是因为加载库时出现问题,如依赖的函数不存在、内存错误、初始化失败或API使用不当等。为了防止动态库崩溃导致程序终止,可以采取一些措施来捕获和处理这些异常。 1. 异常处理:C++提供异常处理机制,你可以使用try-catch语句块来捕获并处理运行时错误。当动态库中的代码抛出异常时,如果被相应的catch块捕获,可以执行清理操作并决定如何继续执行(例如,记录日志、返回错误代码或者恢复到安全状态)。 ```cpp try { // 调用动态库中的函数 } catch (std::exception& e) { // 处理异常 std::cerr << "Caught exception: " << e.what() << std::endl; } ``` 2. 使用C++异常安全函数:对于API调用,确保使用那些支持异常安全的接口。这通常意味着它们不会在内部抛出异常,即使出现错误也会返回错误代码。 3. 初始检查:在调用动态库函数之前,进行必要的检查,如检查函数是否存在、参数是否正确等。 4. 错误码检查:许多库函数会返回错误码,检查返回值可以提前发现并处理潜在问题。 5. 使用动态链接库加载器(如Windows的LoadLibraryEx或Linux的dlopen/dlclose):这些函数提供了错误信息,可以帮助诊断问题。 然而,即使采取了这些措施,动态库崩溃仍然是可能发生的,因为有些错误是无法预测或避免的。在这种情况下,完全避免崩溃并不总是现实的,但可以显著降低其发生概率并提供更好的用户体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值