_GLIBCXX_USE_CXX11_ABI、GCC 4.8 和 ABI 兼容性

2024-01-28

我们收到了一些为 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 我们就能完成这项工作吗?

Thanks!


可以将 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 to /etc/ld.so.conf,或使用-Wl,-rpath /usr/local/gcc-5.4.0/lib64.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

_GLIBCXX_USE_CXX11_ABI、GCC 4.8 和 ABI 兼容性 的相关文章

随机推荐