我试图编译我的程序,它返回这个错误:

usr/bin/ld: cannot find -l<nameOfTheLibrary>

在我的makefile中,我使用命令g++并链接到我的库,这是一个符号链接到我的库位于另一个目录。

是否有一个选项添加,使其工作,请?


当前回答

编译时

当g++说不能找到-l< nameoftheelibrary >时,这意味着g++查找的文件是lib{nameoftheelibrary}。但它无法在共享库搜索路径中找到它,而共享库搜索路径默认指向/usr/lib和/usr/local/lib或者其他地方。

要解决这个问题,您应该在这些搜索路径中提供库文件(lib{nameoftheelibrary}.so),或者使用-L命令选项。-L{path}告诉g++(实际上是ld)在默认路径之外查找路径{path}中的库文件。

示例:假设在/home/taylor/libswift. .有一个库你想把你的应用链接到这个库。在这种情况下,你应该为g++提供以下选项:

g++ main.cpp -o main -L/home/taylor -lswift

注意1:-l选项在开始和结束时获取库名,不包含lib和.so。 注意2:在某些情况下,库文件名后面跟着它的版本,例如libswift.so.1.2。在这些情况下,g++也无法找到库文件。解决这个问题的一个简单方法是创建一个到libswift.so.1.2的符号链接,称为libswift.so。


运行时

当你将你的应用链接到一个共享库时,库必须在你运行应用时保持可用。在运行时,你的应用(实际上是动态链接器)在LD_LIBRARY_PATH中寻找它的库。它是一个存储路径列表的环境变量。

示例:在我们的libswift。例如,动态链接器找不到libswift。因此在LD_LIBRARY_PATH(指向默认搜索路径)中。要解决这个问题,您应该将该变量附加到路径libswift。现在也是这样。

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/taylor

其他回答

在g++编译期间,如果使用-Loption改变Makefile可能不合适,则通过make define LIBRARY_PATH。我把额外的库放在/opt/lib中,所以我做了:

$ export LIBRARY_PATH=/opt/lib/

然后运行make以成功编译和链接。

使用共享库运行程序定义:

$ export LD_LIBRARY_PATH=/opt/lib/

在执行程序之前。

当你编译你的程序时,你必须提供库的路径;在g++中使用-L选项:

g++ myprogram.cc -o myprogram -lmylib -L/path/foo/bar

如果你的库名是libxyz。因此,它位于路径上,说:

/home/user/myDir

然后将其链接到您的程序:

g++ -L/home/user/myDir -lxyz myprog.cpp -o myprog

除了已经给出的答案,也可能是*。因此文件存在,但没有正确命名。也可能是*。所以文件存在,但它由另一个用户/ root拥有。

问题1:名称不当

如果您将文件链接为-l<nameOfLibrary> 那么库文件名必须是lib<nameOfLibrary>的形式 如果你只有<nameOfLibrary>。重命名文件!

问题2:错误的所有者

为了验证这不是问题-做

ls -l /path/to/.so/file

如果文件由root或其他用户拥有,则需要执行

sudo chown yourUserName:yourUserName /path/to/.so/file

我试图链接到的库有一个非标准的名称(即没有'lib'前缀),所以他们建议使用这样的命令来编译它-

包含lib/cspice。一个- lm