编译过程中关于 boost 静态库的链接错误"undefined reference"

Linking error "undefined reference" about boost static library during compiling

本文关键字:错误 链接 undefined reference 过程中 boost 静态 编译      更新时间:2023-10-16

我正试图在Linux x64上使用boost库1.57编译我的C++项目。

这个项目是用scons编译的,我在我的Arch Linux上成功地编译了它,但这次在Ubuntu机器上失败了。

我为链接添加了-lboost_coroutine标志,但错误"未定义引用"仍然存在。

/usr/bin/g++ -o build/gcc.release/app -pthread -g
build/gcc.release/src/han/unity/rpcx.o 
-lpthread -lz -lboost_coroutine -lboost_context -lboost_date_time 
build/gcc.release/src/han/unity/rpcx.o: In function `attributes':
/usr/local/include/boost/coroutine/attributes.hpp:31: undefined reference 
to `boost::coroutines::stack_traits::default_size()'

我注意到attributes.hpp正是boost协程头文件之一。我试着用nm来提升协同程序库,这似乎没有问题。

nm /usr/local/lib/libboost_coroutine.a | grep "default_size"
0000000000000170 T _ZN5boost10coroutines12stack_traits12default_sizeEv

我搜索了这个错误的可能原因,大多数是关于链接器标志的顺序。在这种情况下,rpcx.o依赖于boost_coroutine,所以它出现在前面。

原因还有哪些?

经过几个小时的努力,我终于解决了这个问题

原来是旧的boost(v1.55)库仍然存在,它有与我手动安装的boost库(v1.57)同名的静态库。链接器在v1.57之前发现了v1.55静态库,所以它使用这些库进行链接。然而,在旧版本中,函数boost::coroutines::stack_traits::default_size()仍然没有被引入,这使得链接器无法找到该函数的正确位置,并返回"未绑定引用"。

对于那些碰巧在编译过程中从谷歌搜索"未定义引用"错误中发现这些问题的人,我了解了调试这类问题的几个步骤,并在这里为您提供了信息。

  1. 检查链接的库是否存在于/usr/lib//usr/local/lib/中,如果不存在,请尝试先安装这些库。

  2. 检查是否为引用的库添加了正确的链接标志。例如,如果使用boost_coroutine库,请确保在链接期间添加-lboost_coroutine

  3. 检查链接标志的顺序是否正确(对于gcc)。这可能是大多数情况的原因。如果B依赖于A,请确保将B放在A前面。

  4. 检查同一库是否存在不同的版本。

我希望这些能有所帮助。

相关文章: