美文网首页
如何修复这个错误 /usr/lib/libstdc++.so.6

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

作者: 东东东东东东丶 | 来源:发表于2018-07-04 10:12 被阅读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从链接目录拷贝到程序运行目录,然后运行程序,并正常工作。

    相关文章

      网友评论

          本文标题:如何修复这个错误 /usr/lib/libstdc++.so.6

          本文链接:https://www.haomeiwen.com/subject/vhlcuftx.html