0

在我从源代码(Nix 2.3 FWIW)构建的项目中,一个共享库(libnixstore.so)与另一个共享库(libnixutil.so)链接。命令行是:

x86_64-slackware-linux-g++ -std=c++17 -o /d/tmp/SBo/nix-2.3/src/libstore/libnixstore.so -shared -L/usr/lib64 -Wl,--no-copy-dt-needed-entries src/libstore/binary-cache-store.o src/libstore/build.o src/libstore/builtins/buildenv.o src/libstore/builtins/fetchurl.o src/libstore/crypto.o src/libstore/derivations.o src/libstore/download.o src/libstore/export-import.o src/libstore/gc.o src/libstore/globals.o src/libstore/http-binary-cache-store.o src/libstore/legacy-ssh-store.o src/libstore/local-binary-cache-store.o src/libstore/local-fs-store.o src/libstore/local-store.o src/libstore/machines.o src/libstore/misc.o src/libstore/nar-accessor.o src/libstore/nar-info-disk-cache.o src/libstore/nar-info.o src/libstore/optimise-store.o src/libstore/parsed-derivations.o src/libstore/pathlocks.o src/libstore/profiles.o src/libstore/references.o src/libstore/remote-fs-accessor.o src/libstore/remote-store.o src/libstore/s3-binary-cache-store.o src/libstore/sqlite.o src/libstore/ssh-store.o src/libstore/ssh.o src/libstore/store-api.o -lsqlite3 -ldl -lbz2 -lcurl  -pthread -ldl -lseccomp -Wl,-z,defs -Wl,-soname=libnixstore.so    -Wl,-rpath,/d/tmp/SBo/nix-2.3/src/libutil -Lsrc/libutil -lnixutil

该命令行是“配置”脚本产生的。但是,这失败了,通知没有从“libnixutil.so”中找到很多符号。未解析的符号实际上存在,并且具有正确的修饰(我检查过,使用“nm”和“readelf”)。现在,如果我只是将 '-lnixutil' 替换为 'src/libutil/libnixutil.so',链接就可以完成。有什么区别,是否记录在案?我在“man ld”中看不到任何合适的内容,并且(似乎)在网络搜索中没有直接相关的内容。

4

1 回答 1

1

现在,如果我只是将 '-lnixutil' 替换为 'src/libutil/libnixutil.so',链接就可以完成。有什么不同

不同之处在于-lnuxutil在各种目录中搜索库,而src/libutil/libnixutil.so没有。

由于 using-lnuxutil在找到库时无法链接,因此可以安全地假设它在 in 以外的某个地方找到了该库src/libutil的版本,并且它找到的版本可能是错误的(即旧版本)。

要查看链接器找到的位置libnixutil,请使用-Wl,-t标志(它将显示链接器打开的所有输入文件)。

于 2019-10-07T14:48:42.100 回答