0

我正在尝试安装一个明确声称需要安装 boost 的 linux 工具。(http://www.statmt.org/moses/?n=Development.GetStarted)

我已经下载了boost1.42的源代码(放入/usr/local/boost1.42)进行编译。虽然编译过程产生了很多错误和警告(正常吗?boost官网说应该不会有其他错误,除了IO错误。),最后我得到了/usr中的/stage/lib和/boost /local/boost1.42 目录。现在我可以运行如下示例:

 #include <boost/regex.hpp>
#include <iostream>
#include <string>

int main()
{
    std::string line;
    boost::regex pat( "^Subject: (Re: |Aw: )*(.*)" );

    while (std::cin)
    {
        std::getline(std::cin, line);
        boost::smatch matches;
        if (boost::regex_match(line, matches, pat))
            std::cout << matches[2] << std::endl;
    }
}

 $ c++ -I /usr/local/boost_1_42_0 example.cpp -o example -L~/usr/local/boost_1_42_0/stage/lib/ -lboost_regex

这实际上会发出一个可执行文件“示例”,没有编译警告和正确的行为。但是当我想查看它的链接细节时:

$ldd -v example

结果相当混乱:

    linux-vdso.so.1 =>  (0x00007fffb4b9c000)
    libboost_regex.so.1.42.0 => not found
    libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x0000003f79600000)
    libm.so.6 => /lib64/libm.so.6 (0x0000003f72e00000)
    libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x0000003f78e00000)
    libc.so.6 => /lib64/libc.so.6 (0x0000003f72200000)
    libpthread.so.0 => /lib64/libpthread.so.0 (0x0000003f72a00000)
    /lib64/ld-linux-x86-64.so.2 (0x0000003f71e00000)

    Version information:
    ./example:
            libgcc_s.so.1 (GCC_3.0) => /lib64/libgcc_s.so.1
            libpthread.so.0 (GLIBC_2.2.5) => /lib64/libpthread.so.0
            libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6
            libstdc++.so.6 (CXXABI_1.3) => /usr/lib64/libstdc++.so.6
            libstdc++.so.6 (GLIBCXX_3.4) => /usr/lib64/libstdc++.so.6
    /usr/lib64/libstdc++.so.6:
            libm.so.6 (GLIBC_2.2.5) => /lib64/libm.so.6
            ld-linux-x86-64.so.2 (GLIBC_2.3) => /lib64/ld-linux-x86-64.so.2
            libgcc_s.so.1 (GCC_4.2.0) => /lib64/libgcc_s.so.1
            libgcc_s.so.1 (GCC_3.3) => /lib64/libgcc_s.so.1
            libgcc_s.so.1 (GCC_3.0) => /lib64/libgcc_s.so.1
            libc.so.6 (GLIBC_2.4) => /lib64/libc.so.6
            libc.so.6 (GLIBC_2.3) => /lib64/libc.so.6
            libc.so.6 (GLIBC_2.3.2) => /lib64/libc.so.6
            libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6
    /lib64/libm.so.6:
            libc.so.6 (GLIBC_PRIVATE) => /lib64/libc.so.6
            libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6
    /lib64/libgcc_s.so.1:
            libc.so.6 (GLIBC_2.4) => /lib64/libc.so.6
            libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6
    /lib64/libc.so.6:
            ld-linux-x86-64.so.2 (GLIBC_PRIVATE) => /lib64/ld-linux-x86-64.so.2
            ld-linux-x86-64.so.2 (GLIBC_2.3) => /lib64/ld-linux-x86-64.so.2
    /lib64/libpthread.so.0:
            ld-linux-x86-64.so.2 (GLIBC_2.3) => /lib64/ld-linux-x86-64.so.2
            ld-linux-x86-64.so.2 (GLIBC_2.2.5) => /lib64/ld-linux-x86-64.so.2
            ld-linux-x86-64.so.2 (GLIBC_PRIVATE) => /lib64/ld-linux-x86-64.so.2
            libc.so.6 (GLIBC_2.3.2) => /lib64/libc.so.6
            libc.so.6 (GLIBC_PRIVATE) => /lib64/libc.so.6
            libc.so.6 (GLIBC_2.2.5) => /lib64/libc.so.6

似乎链接器在 /usr/local/boost1.42/stage/lib/libboost_regex.a 中没有找到 libboost_regex.a (参见 ldd 日志:libboost_regex.so.1.42.0 => 未找到)。

那么它真正想要加载哪个库?为什么“未找到”会产生正确的可执行文件?

如果我想确保 boost 安装成功,我是否必须将 /usr/local/boost1.42 和 /usr/local/boost1.42/stage/lib 导出到任何地方,以便其他程序可以知道它的位置?

谢谢!洪斌

4

2 回答 2

3

要在非标准位置(未在 ld.so.conf 中指定)安装 boost 并使用它,请执行以下操作:

  1. --prefix使用和--libdir选项配置升压:

    $ ./bootstrap.sh --prefix=${PREFIX} --libdir=${PREFIX}/lib64
    
  2. 构建并安装 boost 设置 rpath 为相同的值--libdir,例如${PREFIX}/lib64

    $ ./b2 -d+2 --layout=system variant=release link=shared threading=multi runtime-link=shared linkflags="-Wl,-rpath,${PREFIX}/lib64"
    
    $ sudo ./b2 -d+2 --layout=system variant=release link=shared threading=multi runtime-link=shared linkflags="-Wl,-rpath,${PREFIX}/lib64" install
    
  3. 编译你的应用程序指定 boost 包含目录:

    $ g++ -c -I${PREFIX}/include ...
    
  4. 链接指定 boost lib 位置的应用程序。还将 rpath 嵌入二进制文件中,以便应用程序可以找到 boost 库而不必摆弄LD_LIBRARY_PATH

    $ g++ -L${PREFIX}/lib64 -Wl,-rpath,${PREFIX}/lib64 ...
    

在上面设置 PREFIX 以提升安装位置,例如export PREFIX=/usr/local/my_boost.

于 2012-05-14T10:30:37.813 回答
0

是的,您需要告诉动态链接器共享对象(.so文件,而不是.a文件)的位置。

这可以通过设置LD_LIBRARY_PATH正确的路径(并导出该路径)或编辑/etc/ld.so.conf(或其他一些设置文件,取决于发行版)来完成。

(另一种选择是在链接可执行文件时使用rpath选项,但环境设置对于开发来说更加灵活。)

于 2012-05-14T05:07:30.853 回答