如何修复这个错误 /usr/lib/libstdc++.so.6

2018-07-04  本文已影响0人  东东东东东东丶

原文:How to fix: /usr/lib/libstdc++.so.6: version `GLIBCXX_3.4.15' not found

翻译:

现在我急于想找到这个问题的解决办法,我在32位乌班图下面尝试编译共享库(在Debian和乌班图64位下尝试过,但是都没有成功)

每次我尝试加载我的插件的时候都会得到这个错误:/usr/lib/libstdc++.so.6: version ``GLIBCXX_3.4.15' not found

下面是我得到这个错误的方法:

1.安装最新的32位乌班图

2.安装 sudo apt-get install build-essential

3.编译并加载我的插件

下面是一些我找到并尝试的链接,但是对我来说都没有实际用途:

(我的老问题:在发布这个问题的几天后我处理掉了它,但是我忘记了我是如何操作的)

My Question

Another user with the same problem

And another

我看到某些人移动lidstdc++(我认为)到一些目录中来解决这个问题,通过idk指向或者链接到目录,但是这让我很疑惑。

有人知道这个问题吗?

(第一次修改)在终端中运行 strings /usr/lib/libstdc++.so.6 | grep GLIBC得到了:strings '/usr/lib/libstdc++.so.6': No such file,这是一个问题吗?如果是的话,我应该安装哪个库呢?

(第二次修改)有人知道解决方案吗?

(第三次修改)仍然需要一个解决方案,有没有方法查看共享库是在哪个发行版本上编译的吗?我知道我前一阵子编译过这个库,但是我忘记了

(第四次修改)ldd my_lib_.so得到了:

linux-gate.so.1 => (0xb77d7000)

    libstdc++.so.6 => /usr/lib/i386-linux-gnu/libstdc++.so.6 (0xb76c1000)

    libgcc_s.so.1 => /lib/i386-linux-gnu/libgcc_s.so.1 (0xb76a4000)

    libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xb74fa000)

    libm.so.6 => /lib/i386-linux-gnu/libm.so.6 (0xb74ce000)

    /lib/ld-linux.so.2 (0xb77d8000)

ldd program_im_loading_so_into得到了:

linux-gate.so.1 => (0xb77d8000)

    libdl.so.2 => /lib/i386-linux-gnu/libdl.so.2 (0xb77c0000)

    libpthread.so.0 => /lib/i386-linux-gnu/libpthread.so.0 (0xb77a5000)

    libstdc++.so.6 => /usr/lib/i386-linux-gnu/libstdc++.so.6 (0xb76bb000)

    libm.so.6 => /lib/i386-linux-gnu/libm.so.6 (0xb768f000)

    libgcc_s.so.1 => /lib/i386-linux-gnu/libgcc_s.so.1 (0xb7672000)

    libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xb74c9000)

    /lib/ld-linux.so.2 (0xb77d9000)

运行 strings /usr/lib/i386-linux-gnu/libstdc++.so.6 | grep GLIBCXX得到了:

GLIBCXX_3.4

GLIBCXX_3.4.1

GLIBCXX_3.4.2

GLIBCXX_3.4.3

GLIBCXX_3.4.4

GLIBCXX_3.4.5

GLIBCXX_3.4.6

GLIBCXX_3.4.7

GLIBCXX_3.4.8

GLIBCXX_3.4.9

GLIBCXX_3.4.10

GLIBCXX_3.4.11

GLIBCXX_3.4.12

GLIBCXX_3.4.13

GLIBCXX_3.4.14

GLIBCXX_3.4.15

GLIBCXX_3.4.16

GLIBCXX_3.4.17

GLIBCXX_3.4.18

GLIBCXX_3.4.19

GLIBCXX_DEBUG_MESSAGE_LENGTH

我的gcc的版本是:

`gcc version 4.6.4 (Ubuntu/Linaro 4.6.4-1ubuntu1~12.04)`


Answers1:

使用 gcc的选项 -static-libstdc++,来链接静态库。


Answers2:

我通过安装 sudo apt-get install libstdc++6解决了这个问题。

在我的环境中,我安装完  MongoDB 3.0.1遇到了这个问题:

mongo: /usr/lib/x86_64-linux-gnu/libstdc++.so.6: version `GLIBCXX_3.4.18' not found (required by mongo)


Answers3:

在非默认的存储库中安装最新的版本即可:

$ sudo add-apt-repository ppa:ubuntu-toolchain-r/test

$ sudo apt-get update

$ sudo apt-get install libstdc++6-4.7-dev


Answers4:

通过安装最新版本的libstdc++可以解决这个问题:

$ sudo add-apt-repository ppa:ubuntu-toolchain-r/test

$ sudo apt-get update

$ sudo apt-get install libstdc++6-7-dbg


Answers5:

在上面,你提到编译库是复现问题的一个步骤,但是下面你编辑说:

“有没有方法看动态库实在哪个发行版本上编译的”

对C++程序来说,你是否在同一个发行版本上编译,甚至同一发行版本的不同版本之间编译是很重要的细节。

就像我说的,链接C++库包括 libstdc++会导致混合的结果。这里是使用不同版本的C++重新编译的一些相关问题:

do we need to recompile libraries with c++11?

基本上,如果你在不同发行版本上编译C++(可能还有不同的gcc版本),这可能是引起你问题的原因。

我认为你有两个选择:

1.最好的选择:重新编译你的共享库,如果你没在你当前系统上编译过的话。如果这里有运行时期系统环境变量的问题的话,在编译期间可能就会出现;

2.将你的应用程序和其他C++编译库绑定在一起。如果是相同的发行版本,这可能是唯一可行的办法。这可能是一个有用的方法如果你有自己的编译器。如果你使用这个方法,你必须设置LD_LIBRARY_PATH并让它生效,在绑定上你的stdc++库。


Answers6:

如果有人和我遇到了一样的问题,确定你没有在乌班图12.04的机器上安装14.04的软件包-它会给出同样的错误。重新安装合适的存储库来解决这个问题。


Answers7:

这对我来说是有效的:

cp /libstdc++.so.6 $PWD

./<executable>

这个解决方案来自于@kerin(上面的评论中):

你可以在这里查看到 http://stackoverflow.com/questions/13636513/linking-libstdc-statically-any-gotchas

从上面的链接中:

如果你把最新的libstdc++库放到应用程序执行的目录,你会发现在运行的时候问题就解决了。

我得到的这个错误中的 libstdc++库在 /usr/lib64/这个目录中,但是这不是我链接的库,消息看起来像:

: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by )

我确认 LD_LIBRARY_PATH含有这个目录(而且是第一个)。出于某种原因,在运行时仍然查看 /usr/lib64/libstdc++.so.6。

我采取了上面的建议,把 libstdc++.so.6从链接目录拷贝到程序运行目录,然后运行程序,并正常工作。

上一篇下一篇

猜你喜欢

热点阅读