10

我正在编译一个名为“询问”的可执行文件:

g++ -o built/bin/interrogate -Lbuilt/lib -Lbuilt/tmp -L/usr/X11R6/lib \
建/tmp/interrogate_composite1.o 建/tmp/interrogate_composite2.o \
-lp3cppParser -lp3dtool -lp3dtoolconfig -lp3pystub -pthread -ldl

编译后,当我尝试执行可执行文件时:

$ LD_LIBRARY_PATH=built/lib built/bin/interrogate
built/bin/interrogate:符号查找错误:built/lib/libp3dtool.so.1.8:未定义符号:_Py_NoneStruct

此符号由 libp3pystub.so 提供,但询问可执行文件没有对此库的任何引用(我确实使用了 -lp3pystub):

$ LD_LIBRARY_PATH=built/lib ldd built/bin/interrogate
    linux-vdso.so.1 => (0x00007fff2016a000)
    libp3dtool.so.1.8 => 内置/lib/libp3dtool.so.1.8 (0x00007f498d57a000)
    libp3dtoolconfig.so.1.8 => 内置/lib/libp3dtoolconfig.so.1.8 (0x00007f498d51b000)
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007f498d1f2000)
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f498cfdc000)
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f498cdbf000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f498c9ff000)
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f498c7fb000)
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f498c4ff000)
    /lib64/ld-linux-x86-64.so.2 (0x00007f498d5bc000)

如果我手动加载 libp3pystub.so,可执行文件有效:

$ LD_PRELOAD=built/lib/libp3pystub.so LD_LIBRARY_PATH=built/lib built/bin/interrogate

用法:
  询问 [opts] file.C [file.C ...]
  询问 -h

我的问题是:为什么可执行文件-lp3pystub没有引用我添加的库?interrogate

4

1 回答 1

16

我实际上自己找到了答案。我在 Ubuntu 上编译,他们添加了一个默认优化标志:-Wl,--as-needed. 此优化检查是否在主可执行文件中没有使用通过 -l 传递的库中的符号,它们将被删除。

这就是我的错误所在:_Py_NoneStruct 不是由询问直接使用,而是由另一个共享库使用。所以我必须手动指定需要 p3pystub。

一种可能的解决方法是:

$ g++ -o built/bin/interrogate -Lbuilt/lib -Lbuilt/tmp -L/usr/X11R6/lib \
建/tmp/interrogate_composite1.o 建/tmp/interrogate_composite2.o \
-Wl,--不需要 -lp3cppParser -lp3dtool -lp3dtoolconfig -lp3pystub \
-pthread -ldl

然后我正确地在 ldd 输出中获得了库:

$ LD_LIBRARY_PATH=built/lib ldd built/bin/interrogate
    linux-vdso.so.1 => (0x00007fff0edff000)
    libp3dtool.so.1.8 => 内置/lib/libp3dtool.so.1.8 (0x00007fa1c36be000)
    libp3dtoolconfig.so.1.8 => 内置/lib/libp3dtoolconfig.so.1.8 (0x00007fa1c365f000)
>>> libp3pystub.so.1.8 => 内置/lib/libp3pystub.so.1.8 (0x00007fa1c3658000)
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fa1c342f000)
    libstdc++.so.6 => /usr/lib/x86_64-linux-gnu/libstdc++.so.6 (0x00007fa1c312c000)
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007fa1c2e2f000)
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007fa1c2c19000)
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fa1c29fc000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fa1c263c000)
    /lib64/ld-linux-x86-64.so.2 (0x00007fa1c3700000)

参考: https ://wiki.ubuntu.com/NattyNarwhal/ToolchainTransition

于 2013-01-15T02:32:08.833 回答