2020/3/16
1 问题前身
上次,我在Linux的QT下面实现了共享库的创建以及调用,不知道的如何创建和调用共享库的可以 参考这里.
但是,出现了点问题,具体是,我在QT Creator界面下直接点击编译运行能够运行,但是在编译过程中创建的文件下,点击文件下的可执行文件,却不能直接运行。
今天在打包QT程序的时候解决了该问题。
2 问题发现
首先,打包QT程序,具体QT程序在Linux下的打包方式,可以点击这里.
然后,点击打包好的文件夹里面的可执行程序,结果点不开。报错,
error while loading shared libraries: libXXX.so.X: cannot open shared object file: No such file
3 问题解决
3.1 分析原因
这个错误是说 链接器ld 找不到库文件,可是需要的库文件就在当前目录。
链接器ld在搜索用得上的库文件时,默认去/lib和/usr/lib这两个路径下面去搜索,也就是说,在这两个路径下面链接器ld并没有找到它需要的库文件,所以报错了。
那解决思路就有了,我们得想办法让ld找到它需要的库文件,那么一个就是将我们需要的库放入这两个默认的路径下面,另外一个就是增加链接器ld搜索库的路径。
3.2 解决办法
方法1
首先,打开 /etc/ld.so.conf 文件,在这个文件里面加入一行新的内容,内容就是库文件所在的目录;
然后,运行 ldconfig(用来更新/etc/ld.so.cache)
方法2
首先,在/etc/ld.so.conf.d/目录下新建任何以.conf为后缀的文件,在该文件中加入库文件所在的目录;
然后,运行 ldconfig(用来更新/etc/ld.so.cache)
3.3 具体操作
/etc/ld.so.conf文件的内容是include /etc/ld.so.conf.d/*.conf
# 1. 将需要用到的所有库都放到/usr/local/lib;
sudo cp libXXX.so.X /usr/local/lib/
# 2. 在/etc/ld.so.conf.d/目录下新建文件usr-libs.conf,内容是:/usr/local/lib
sudo gedit usr-libs.conf
# 3. sudo ldconfig
4 结果
不仅在打包好的文件夹下面可执行文件能够运行,同时在QT Creator编译运行文件时产生的文件夹里面的可执行文件也能够运行。
至此,两个问题都得到了解决。
PS:
-
ld.so.cache的更新是递增式的,就像PATH系统环境变量一样,不是从头重新建立,而是向上累加。
重新开机,才会从零开始建立ld.so.cache文件。 -
如果共享库文件安装到了/lib或/usr/lib目录下, 那么需执行一下ldconfig命令。
ldconfig命令的用途, 主要是在默认搜寻目录(/lib和/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下,
搜索出可共享的动态链接库(格式如lib*.so*), 进而创建出动态装入程序(ld.so)所需的连接和缓存文件. 缓存文件默认为/etc/ld.so.cache, 此文件保存已排好序的动态链接库名字列表。