_GLIBCXX_USE_CXX11_ABI,GCC 4.8和ABI兼容性

时间:2017-07-31 13:47:26

标签: c++ linux c++11 gcc

我们收到了一些为linux编译的库(.a)(可能是用GCC 6.x编译的)。

我们正在使用GCC 4.8,我们得到的类型错误: 尝试链接时undefined reference to std::__cxx11::basic_string

通常可以通过确保所有单元都使用相同的_GLIBCXX_USE_CXX11_ABI标志进行编译来解决此问题。 但是,如果我理解正确,这是由GCC 5.1引入的。

  1. 有没有办法让这个工作与GCC 4.8一起工作,还是我们需要让人们用不同的_GLIBCXX_USE_CXX11_ABI重新编译库?
  2. 我想如果我们能够切换到GCC> = 5.1,我们可以做到这一点吗?
  3. 谢谢!

1 个答案:

答案 0 :(得分:7)

可以将C ++ 11 ABI与gcc 4.8.2一起使用,但这是一个危险的黑客攻击;如果可能要求您的供应商发布使用C ++ 03 ABI(-D_GLIBCXX_USE_CXX11_ABI=0)编译的库或升级到GCC 5或更高版本,您会好得多。

您需要下载并安装gcc 5,以便您可以使用其libstdc ++标头和库,然后指示gcc 4.8使用它们优先于它自己的那些。另外,因为gcc 4.8缺少gcc 5附带的libstdc ++所需的一些内在函数,所以你需要破解它们的用法。

例如,要编译包含<string>的简单单文件应用程序:

/usr/local/gcc-4.8.2/bin/g++ \
   -std=c++11 \
   -D_GLIBCXX_USE_CXX11_ABI=1 \
   -D'__is_trivially_copyable(...)=0' \
   -D'__is_trivially_constructible(...)=0' \
   -D'__is_trivially_assignable(...)=0' \
   -nostdinc++ \
   -isystem /usr/local/gcc-5.4.0/include/c++/5.4.0/ \
   -isystem /usr/local/gcc-5.4.0/include/c++/5.4.0/x86_64-unknown-linux-gnu \
   -L /usr/local/gcc-5.4.0/lib64
   a.cpp

这很危险,因为gcc 5.4 libstdc ++不适用于gcc 4.8,重新定义使用的内在函数(__is_trivially_copyable等)可能会改变结构的布局或导致程序与程序之间的二进制不兼容供应商的图书馆。

为了运行生成的可执行文件,您还需要确保动态链接器找到兼容的libstdc ++,例如将/usr/local/gcc-5.4.0/lib64添加到/etc/ld.so.conf或使用-Wl,-rpath /usr/local/gcc-5.4.0/lib64