我的一个项目遇到了一些麻烦。似乎我链接到需要pthread符号的库,但库本身没有与pthread链接。症状是当我尝试运行它时程序会出现段错误。我跑了:
LD_DEBUG=all ./my_program
并在寻找pthread_create时发现了segfaults。如果我使用此命令强制预加载pthread,程序将运行:
LD_PRELOAD=/lib/x86_64-linux-gnu/libpthread.so.0 ./my_program
为了解决这个问题,我想我只是使用-lpthread在构建脚本中将my_program与pthread链接起来。这没用,所以我尝试了-pthread。也没用。我能够将其重现为极简:
echo "int main() { return 0; }" | g++ -x c++ - -pthread -lpthread -o my_program && ldd my_program
linux-vdso.so.1 => (0x00007ffe4fd08000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f150ca5c000)
/lib64/ld-linux-x86-64.so.2 (0x000055ac8c275000)
从ldd的输出可以看出,my_program没有与pthread链接。我怀疑这是因为g ++理解我实际上并没有使用pthread中的任何符号并且不与它链接。所以我尝试添加对pthread_create的调用:
echo -e "#include <pthread.h>\n int main() { pthread_create(0,0,0,0); return 0; }" | g++ -x c++ - -pthread -o my_program && ldd my_program
<stdin>: In function ‘int main()’:
<stdin>:2:37: warning: null argument where non-null required (argument 1) [-Wnonnull]
<stdin>:2:37: warning: null argument where non-null required (argument 3) [-Wnonnull]
linux-vdso.so.1 => (0x00007ffd977f9000)
libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007fafe1bb6000)
libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fafe17f1000)
/lib64/ld-linux-x86-64.so.2 (0x0000563ee0002000)
请忽略警告,我知道对pthread_create的调用是假的。关键是现在它实际上与pthread链接。
所以我的问题是:无论如何强制g ++与某些东西(在本例中为pthread)联系而不使用符号添加虚拟代码?
答案 0 :(得分:1)
是否有强制g ++与某些内容(在本例中为pthread)链接而不使用符号添加虚拟代码?
试试这个:
echo "int main() { return 0; }" |
g++ -x c++ - -o my_program -Wl,--no-as-needed -lpthread -Wl,--as-needed