【问题标题】:Linking issue with g++ and glibmmg++ 和 glibmm 的链接问题
【发布时间】:2018-02-01 17:18:43
【问题描述】:

我正在尝试编译 gobby,但编译因以下错误而停止:

/usr/lib64/gcc/x86_64-slackware-linux/4.9.3/../../../../lib64/libglibmm-2.4.so: undefined reference to `std::out_of_range::out_of_range(char const*)@GLIBCXX_3.4.21'
/usr/lib64/gcc/x86_64-slackware-linux/4.9.3/../../../../lib64/libglibmm-2.4.so: undefined reference to `std::underflow_error::underflow_error(char const*)@GLIBCXX_3.4.21'
/usr/lib64/gcc/x86_64-slackware-linux/4.9.3/../../../../lib64/libglibmm-2.4.so: undefined reference to `std::overflow_error::overflow_error(char const*)@GLIBCXX_3.4.21'

第一反应是检查链接命令。结局是这样的:

... -lgsasl -lgnutls -lgtkmm-3.0 -latkmm-1.6 -lgdkmm-3.0 -lgiomm-2.4 -lpangomm-1.4 **-lglibmm-2.4** -lcairomm-1.0 -lsigc-2.0 -lgtksourceview-3.0 -lgtk-3 -lgdk-3 -lpangocairo-1.0 -lpango-1.0 -latk-1.0 -lcairo-gobject -lcairo -lgdk_pixbuf-2.0 -lgio-2.0 -lgobject-2.0 -lglib-2.0 -linfgtk-0.7 -linftextgtk-0.7 -linftext-0.7 -linfinity-0.7 -lxml2 -lgnutls -lgsasl -lgtk-3 -lgdk-3 -lpangocairo-1.0 -lpango-1.0 -latk-1.0 -lcairo-gobject -lcairo -lgdk_pixbuf-2.0 -lgio-2.0 -lgobject-2.0 -lglib-2.0

(我用** 标记了-lglibmm-2.4 库。我怀疑应该在这里定义标识符。为了确保我跑了:

$ objdump -TC libglibmm-2.4.so.1.3.0 | grep out_of_range
0000000000000000      DF *UND*  0000000000000000  GLIBCXX_3.4.21 std::out_of_range::out_of_range(char const*)
0000000000000000      DF *UND*  0000000000000000  GLIBCXX_3.4 std::out_of_range::~out_of_range()
0000000000000000      DF *UND*  0000000000000000  GLIBCXX_3.4.20 std::__throw_out_of_range_fmt(char const*, ...)
0000000000000000      DO *UND*  0000000000000000  GLIBCXX_3.4 typeinfo for std::out_of_range

$ objdump -TC libglibmm-2.4.so.1.3.0 | grep overflow_error
0000000000000000      DF *UND*  0000000000000000  GLIBCXX_3.4.21 std::overflow_error::overflow_error(char const*)
0000000000000000      DF *UND*  0000000000000000  GLIBCXX_3.4 std::overflow_error::~overflow_error()
0000000000000000      DO *UND*  0000000000000000  GLIBCXX_3.4 typeinfo for std::overflow_error

因此,它们似乎在 .so 文件中未定义。那么应该在哪里定义呢?

【问题讨论】:

  • @RinatVeliakhmedov,我刚刚运行了 ./configure 和 make - tar.gz 中的原始文件没有进行任何更改
  • 您是否链接到为不同平台预先构建的内容?那是我以前见过这样的问题的时候。
  • @xaxxon,不确定你在问什么 - 交叉编译?一切都是“本机”的,我正在 x86_64 上编译,这也是目的地。
  • 否,您是否下载了未专门针对您所在的确切平台编译的预编译库?就像为不同版本的 ubuntu 抢一个,而不是你正在运行的(或其他)
  • @xaxxon 好的。我正在使用 Slackware,所以基本上我会编译所有内容。如果有的话,我会使用来自 Slackbuilds.org 的优秀“食谱”,但在这种情况下,那里的虾虎鱼版本有些过时了。可悲的是,我需要的软件也经常在那里不可用,所以我不得不依靠编译。

标签: c++ std undefined-reference


【解决方案1】:

好吧,我解决了编译问题,但这会产生另一个问题:

     19 Aug 23 21:39 libstdc++.so        -> libstdc++.so.6.0.20
     18 Sep  3  2016 libstdc++.so.5      -> libstdc++.so.5.0.7
4515618 Jun  5  2013 libstdc++.so.5.0.7
     19 Sep  3  2016 libstdc++.so.6      -> libstdc++.so.6.0.21
 966848 Jul 30  2012 libstdc++.so.6.0.17
1003520 Aug 19  2015 libstdc++.so.6.0.20
1533144 Mar  7  2016 libstdc++.so.6.0.21

我不久前更新了libstdc++后,版本从6.0.20增加到6.0.21,即使手动调用ldconfiglibstdc++.so仍然指向6.0.20版本。手动将此链接更改为6.0.21 解决了该问题。

我的印象是ldconfig 应该解决这个问题。手册页和搜索都没有显示确切的算法ldconfig 遵循...我错了吗?

【讨论】:

  • 不,ldconfig 不关心这个链接。 ldconfig 关心运行时,即在程序执行时定位正确的库。 libstdc++.so 的链接只与 link time 相关(当您的链接器在编译后生成程序时),但与运行时无关。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-04-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多