ubuntu下boost编写翻译安装

boost

安装

环境:Ubuntu 12.04 32bit,boost 1.49

环境:Ubuntu 12.04
32bit,boost 1.49

 

1.正视安装

  1. apt-get
    install mpi-default-dev libicu-dev python-dev python3-dev libbz2-dev zlib1g-dev 


初期准备:boost中,用到了别的函数库,所以为了选择boost中相应的法力,要求先安装系统中恐怕缺点和失误的库 

早期准备:boost中,用到了别的函数库,所以为了采用boost中相应的职能,要求先安装系统中或者缺点和失误的库 

Linux上设置使用boost入门引导

2.访问boost官网下载boost最新版本

apt-get install mpi-default-dev  #安装mpi库

apt-get install mpi-default-dev  #安装mpi库

获得boost

3.解压下载文件,例如下载文件在~/Downloads下

  1. cd ~/Downloads 


  2. tar –bzip2 -xvf boost_1_58_0.tar.bz2 


apt-get install libicu-dev     #支撑正则表明式的UNICODE字符集 

apt-get install libicu-dev     #帮助正则表明式的UNICODE字符集 

boost分布

四.备选安装

  1. cd
    boost_1_58 


  2. ./bootstrap.sh 


变动文书b贰和bjam总计md5sum发现两者1致
生成bjam,上述命令可以涵盖种种选项,具体可参看帮忙文书档案: ./bootstrap.sh
–help。其中–prefix参数,能够指虞升卿装路径,假若不带–prefix参数的话(推荐),私下认可路径是
/usr/local/include 和
/usr/local/lib,分别存放头文件和各个库。执行到位后,会生成bjam,已经存在的脚本将会被机关备份。注意,boost
1.4九会在当前目录下,生成三个公文bjam和b二,那四个是相同的,

apt-get install python-dev     #需要python的话

apt-get install python-dev     #需要python的话

只要求头文件的库

5.编译并设置boost

编译达成后,进行安装,相当于将头文件和扭转的库,放到钦赐的门径(–prefix)下

  1. ./b2  //编译boost 


  2. sudo ./b二 install
    //将生成的库安装到/usr/local/lib目录上边,暗许的头文件在/usr/local/include/boost目录下面。 


apt-get install libbz2-dev     #设若编写翻译现身错误:bzlib.h: No such
file or directory

apt-get install libbz2-dev     #要是编写翻译出现错误:bzlib.h: No such
file or directory

运用boost建立叁个粗略的顺序

6.卸载

将/usr/local/lib和/usr/local/include/boost多个目录下的公文从来删除就能够。

上述函数库装好之后,就能够编写翻译boost库了。解压boost_1_49_0.tar.bz2,得到/boost_1_49_0,将当前工作目录切换来此文件夹下。

上述函数库装好之后,就足以编写翻译boost库了。解压boost_1_49_0.tar.bz2,得到/boost_1_49_0,将当前工作目录切换来此文件夹下。

准备使用boost二进制文件库

7.测试安装是不是正确

新建cpp文件

  1. vim boot.cpp 


  2. #include
    <string> 


  3. #include
    <iostream> 


  4. #include
    <boost/version.hpp> 


  5. #include
    <boost/timer.hpp> 


  6. using namespace std; 


  7. int main() 



  8. boost::timer t; 


  9. cout
    << “max
    timespan: ” << t.elapsed_max() / 3600 <<
    “h” <<
    endl; 


  10. cout
    << “min
    timespan: ” << t.elapsed_min() << “s” <<
    endl; 


  11. cout
    << “now time
    elapsed: ” << t.elapsed() << “s” <<
    endl; 


  12. cout
    << “boost
    version” << BOOST_VERSION <<endl; 


  13. cout
    << “boost lib
    version” << BOOST_LIB_VERSION <<endl; 


  14. return
    0; 



编译

  1. g++ boot.cpp -o boot 


  2. ./boot 


中标编写翻译之后会展现结果,最终两行打字与印刷boost版本

  1. max
    timespan: 2.56205e+09h 


  2. min
    timespan: 1e-06s 


  3. now time
    elapsed: 0.000121s 


  4. boost version106300 


  5. boost lib version1_63 


./bootstrap.sh

./bootstrap.sh

把您的程序链接到boost库

生成bjam,上述命令能够分包各样选项,具体可参考帮衬文书档案: ./bootstrap.sh
–help。其中–prefix参数,可以指定安装路径,如若不带–prefix参数的话(推荐),暗中同意路径是
/usr/local/include 和
/usr/local/lib,分别存放头文件和各样库。执行到位后,会生成bjam,已经存在的脚本将会被活动备份。注意,boost
壹.4九会在当前目录下,生成四个公文bjam和b二,那八个是壹模一样的,所以接下去的步调,能够用那两在那之中的任意八个来执行。

生成bjam,上述命令能够分包各个选项,具体可参照支持文书档案: ./bootstrap.sh
–help。在那之中–prefix参数,能够指虞诩装路径,若是不带–prefix参数的话(推荐),暗中认可路径是
/usr/local/include 和
/usr/local/lib,分别存放头文件和种种库。执行到位后,会生成bjam,已经存在的本子将会被自动备份。注意,boost
1.4九会在当前目录下,生成五个文本bjam和b2,这多个是同壹的,所以接下去的步子,能够用那两其中的任意二个来实施。

1.获得boost

using mpi ;  #只要急需MPI功用,须要在 /tools/build/v2/user-config.jam
文本的末尾添加

using mpi ;  #设若急需MPI成效,需求在 /tools/build/v2/user-config.jam
文本的最终添加

下载boost_1_46_1.tar.bz2

接下去便是使用生成的bjam脚本编译源代码了

接下去正是运用生成的bjam脚本编写翻译源代码了

解压

./b2 -a
-sHAVE_ICU=1  #-a参数,代表重新编写翻译,-sHAVE_ICU=一代表援助Unicode/ICU

./b2 -a
-sHAVE_ICU=1  #-a参数,代表重新编写翻译,-sHAVE_ICU=1代表帮忙Unicode/ICU

2.boost分布

只顾,那里是任何编写翻译。当然也足以选择只编写翻译一部分,选项
–with-<library>
只编写翻译钦定的库,如输入–with-regex就只编写翻译regex库了。boost一.49的一点一滴编写翻译,在笔者速龙® Core™二 Duo CPU T5750 @ 2.00GHz × 二 ,贰G
DDLacrosse2内部存款和储蓄器的老机子上,使用上述选项,半个时辰就大多了。那一个时刻是足以承受的。全体编写翻译安装,心境上呼吸系统感染到也痛快淋漓些。^_^

瞩目,那里是漫天编译。当然也得以选拔只编写翻译一部分,选项
–with-<library>
只编写翻译钦定的库,如输入–with-regex就只编写翻译regex库了。boost一.4九的通通编译,在作者速龙® Core™2 Duo CPU T5750 @ 二.00GHz × 二 ,2G
DD奥迪Q52内部存款和储蓄器的老机子上,使用上述选项,半个钟头就大多了。那几个时间是还不错的。全体编写翻译安装,心思上觉得也不可开交些。^_^

boost_1_46_1…………………….boost根目录

ubuntu下boost编写翻译安装,Ubuntu下编写翻译安装boost库。bjam的有些常用的参数,列表如下:

bjam的片段常用的参数,列表如下:

  boost/……………………………….所有boost头文件

–build-dir=<builddir> 编译的临时文件会放在builddir里(这样比较好管理,编译完就可以把它删除了)
–stagedir=<stagedir> 存放编译后库文件的路径,默认是stage
–build-type=complete

编译所有版本,不然只会编译一小部分版本,确切地说是相当于:

variant=release, threading=multi;link=shared|static;runtime-link=shared

variant=debug|release 决定编译什么版本(Debug or Release?)
link=static|shared 决定使用静态库还是动态库
threading=single|multi 决定使用单线程还是多线程库
runtime-link=static|shared 决定是静态还是动态链接C/C++标准库
–with-<library> 只编译指定的库,如输入–with-regex就只编译regex库了
–show-libraries 显示需要编译的库名称
–build-dir=<builddir> 编译的临时文件会放在builddir里(这样比较好管理,编译完就可以把它删除了)
–stagedir=<stagedir> 存放编译后库文件的路径,默认是stage
–build-type=complete

编译所有版本,不然只会编译一小部分版本,确切地说是相当于:

variant=release, threading=multi;link=shared|static;runtime-link=shared

variant=debug|release 决定编译什么版本(Debug or Release?)
link=static|shared 决定使用静态库还是动态库
threading=single|multi 决定使用单线程还是多线程库
runtime-link=static|shared 决定是静态还是动态链接C/C++标准库
–with-<library> 只编译指定的库,如输入–with-regex就只编译regex库了
–show-libraries 显示需要编译的库名称

  libs/………………………………….Tests,.cpps,docs等的库文件

编写翻译达成后,实行设置,也正是将头文件和变化的库,放到钦赐的门径(–prefix)下

编写翻译完结后,实行安装,也正是将头文件和转移的库,放到钦命的不2秘籍(–prefix)下

注意:

./b2 install

./b2 install

  (1)boost根目录(通常是/usr/local/boost_1_46_1)想到$BOOST_ROOT变量中

从那之后,若是壹切顺遂,就成功安装了。写个小程序检测下,来自《Boost程序库完全开发指南——深远C++“准”标准库(修订版)》(罗剑锋著,电子工业出版社2013.5)

从那之后,要是1切顺利,就成功安装了。写个小程序检查评定下,来自《Boost程序库完全开发指南——长远C++“准”标准库(修订版)》(罗剑锋著,电子工业出版社二零一一.5)

  (二)编写翻译程序时假若用到boost库,须求钦定头文件路径-I$BOOST_ROOT

Boost程序库完全开发指南——深入C++“准”标准库高清PDF版下载: 

Boost程序库完全开发指南——深远C++“准”标准库高清PDF版下载:http://www.linuxidc.com/Linux/2013-07/87574.htm 

  (三)因为具备头文件都在boost文件夹下,并且头文件都以hpp后缀,所#include形如:

#include “stdcpp.hpp”

#include “stdcpp.hpp”

    #include <boost/whaever.hpp>

#include <boost/timer.hpp>

#include <boost/timer.hpp>

3.只需求头文件的库

 

 

  绝大部分的boost库都以header-noly的:它们统统由包蕴模板和inline函数的头文件组成,不须要独自编写翻译和二进制库文件,也不须求链接时特地对待。

using namespace boost;

using namespace boost;

  唯有上面的boost库必需单独built:

 

 

Boost.Filesystem

int main()

int main()

Boost.GraphParallel

{

{

Boost.IOStreams

    timer t;

    timer t;

Boost.MPI

    cout << “max timespan: ” << t.elapsed_max() / 3600
<< “h” << endl;

    cout << “max timespan: ” << t.elapsed_max() / 3600
<< “h” << endl;

Boost.ProgramOptions

    cout << “min timespan: ” << t.elapsed_min() <<
“s” << endl;

    cout << “min timespan: ” << t.elapsed_min() <<
“s” << endl;

Boost.Python (see the Boost.Python build documentation before building
and installing it)

 

 

Boost.Regex

    cout << “now time elapsed: ” << t.elapsed() << “s”
<< endl;

    cout << “now time elapsed: ” << t.elapsed() << “s”
<< endl;

Boost.Serialization

 

 

Boost.Signals

    return EXIT_SUCCESS;

    return EXIT_SUCCESS;

Boost.System

}

}

Boost.Thread

先后输出:

程序输出:

Boost.Wave

max timespan: 0.596523h

max timespan: 0.596523h

  上面那么些单独built是可选(optional)的: 

min timespan: 1e-06s

min timespan: 1e-06s

  Boost.DateTime  Boost.Graph  Boost.Math  Boost.Random  Boost.Test

now time elapsed: 0s

now time elapsed: 0s

4.用到boost建立不难的主次

Ubuntu编译安装boost并在eclipse C/C++中应用

连锁阅读:

  下边包车型大巴次序(example.cc)只用到header-only库。它是从标准输入中读入壹串整数,使用Boost.兰姆da各个数乘以叁后输出。

———————————–分割线———————————–

Ubuntu编写翻译安装boost并在eclipse C/C++中接纳
http://www.linuxidc.com/Linux/2011-04/34790.htm

view sourceprint?

自家也在ubuntu下装了boost,但是碰着了部分难题:
www.bkjia.com @www.bkjia.com:~/Code$ g++ -lboost_filesystem
-lboost_system main.cpp
/tmp/cclYtfBf.o: In function
`__static_initialization_and_destruction_0(int, int)’:
main.cpp:(.text+0x49): undefined reference to
`boost::system::generic_category()’
main.cpp:(.text+0x53): undefined reference to
`boost::system::generic_category()’
main.cpp:(.text+0x5d): undefined reference to
`boost::system::system_category()’
collect2: ld returned 1 exit status

———————————–分割线———————————–

#include <boost/lambda/lambda.hpp>

也正是说加了#include<boost/filesystem.hpp>那句之后随即出错,别的都没难题。不知到你有未有相逢那么些难点吗?

自作者也在ubuntu下装了boost,不过蒙受了部分题材:
www.linuxidc.com @www.linuxidc.com:~/Code$ g++ -lboost_filesystem
-lboost_system main.cpp
/tmp/cclYtfBf.o: In function
`__static_initialization_and_destruction_0(int, int)’:
main.cpp:(.text+0x49): undefined reference to
`boost::system::generic_category()’
main.cpp:(.text+0x53): undefined reference to
`boost::system::generic_category()’
main.cpp:(.text+0x5d): undefined reference to
`boost::system::system_category()’
collect2: ld returned 1 exit status

#include <iostream>

答:

约等于说加了#include<boost/filesystem.hpp>那句之后立刻出错,其他都没难题。不知到您有未有碰着那些题材吧?

#include <iterator>

“boost/filesystem.hpp” 这些文件注重于boost_system,编写翻译的时候,须要-lboost_system选项,不过你的编写翻译选项里头已经内定该选用,为啥还会出现链接错误吗。小编也嫌疑了半天,后来发觉,原来是-l选项的顺序难题。在g++的man支持新闻里面,作者发现了上边包车型大巴话:

答:

#include <algorithm>

引用It makes a difference where in the command you write this option;
the linker searches and processes libraries and object files in the
order they are specified. Thus, foo.o -lz bar.o searches library z after
file foo.o but before bar.o. If bar.o refers to functions in z, those
functions may not be loaded.

“boost/filesystem.hpp” 那个文件正视于boost_system,编写翻译的时候,必要-lboost_system选项,可是你的编写翻译选项里头已经内定该选择,为何还会出现链接错误啊。小编也疑忌了半天,后来意识,原来是-l选项的依次难题。在g++的man支持消息里面,笔者发觉了上边包车型客车话:

 

读完那段话,应该就清楚出错原因了。所以,化解方案就是用下边包车型大巴命令来编写翻译:

引用It makes a difference where in the command you write this option;
the linker searches and processes libraries and object files in the
order they are specified. Thus, foo.o -lz bar.o searches library z
after file foo.o but before bar.o. If bar.o refers to functions in z,
those functions may not be loaded.

int main()

引用g++ main.cpp -lboost_system -lboost_filesystem

读完那段话,应该就明白出错原因了。所以,化解方案正是用下面包车型大巴一声令下来编写翻译:

{

1二.0四 3二bit,boost 一.49先前时代准备:boost中,用到了其他函数库,所以为了利用boost中相应的效果,供给先安装系统中大概缺点和失误的库…

引用g++ main.cpp -lboost_system -lboost_filesystem

    using namespace boost::lambda;

更加多Ubuntu相关音讯见Ubuntu 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=2

    typedef std::istream_iterator<int> in;

金沙注册送58 1

 

    std::for_each(

        in(std::cin), in(), std::cout << (_1 * 3) << ” ”
);

}

编译:g++  -I$BOOST_ROOT  example.cc  -o  example

运行:echo 1 2 3 | ./example

5.备选采用boost贰进制库

  如若您的主次用到必要单独编写翻译的boost库,你必要首先取得这个2进制库文件。

五.壹编写翻译安装全体2进制库文件

  cd $BOOST_ROOT

  ./bootstrap.sh  –help

  ./bootstrap.sh 
–prefix=/usr/local    ##实则暗中同意意况下prefix的值正是/usr/local

  此时变化了bjam可执行文件,那一个东西正是用来编译boost库的。

  ./bjam  install

5.二仅安装钦命的二进制库文件

  上边均运用系统暗中认可的编写翻译器,即Linux上的gcc。

  5.2.1安装Boost.build

  Boost.Build是贰个用以支付、测试、安装软件的依据文本的种类。Boost.Build的生成安装步骤:

  (1)cd $BOOST_ROOT/tools/build/v2

  (2)./bootstrap.sh

  (3)./bjam  install 
–prefix=/usr/local/      ##prefix是Boost.Build安装地方

  (4)把prefix/bin放到PATH中          ##当然/usr/local/bin已经PATH中了

  5.二.贰调用bjam时不钦定toolset则接纳系统默许的编写翻译器。借使你的Linux上装了分裂版本的gcc,则应用toolset选项时能够钦赐版本号:toolset=gcc-四.四

  五.二.三内定build路径,通过–build-dir=/path选项,不点名时默许在脚下路线下开创bin.v2文件夹,把转变的文书放在其内。

  5.2.4调用bjam

  cd  $BOOST_ROOT

  bjam  –build-dir=./build-boost  toolset=gcc   stage

  上面包车型地铁授命将创建static and shared non-debug multi-threaded variants
of the
libraries.如若要树立具有的variants,请使用”–build-type=complete”选项。

  全数的boost二进制库文件将位于stage/lib/下,借使你要其它钦定路线,请使用“–stagedir=directory”选项。

  注意为节省build时间,你可能须求少build壹些库文件:

查看库文件名称  –show-libraries

限制build哪些库  –with-libraryname或者–without-libraryname

选择特定的build variant  adding release or debug to the command line

  友情提示:Boost.Build会转变很多告诉输出,若是您能确认保障建立进程不出错误,你能够禁止那么些输出以节省时间。方法:在指令后增添”>build.log 
二>&1″

陆.把你的程序链接到boost库

  上面包车型地铁顺序是从邮件中抽取“大旨”内容,它选拔了Boost.Regex库,那么些库是内需独自编写翻译的。

view sourceprint?

#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;

    }

}

编译:

方法A:g++  -I$BOOST_ROOT  example.cc -o example 
$BOOST_ROOT/stage/lib/ -lboost_regex.a

方法B:g++  -I$BOOST_ROOT  example.cc -o example 
-L$BOOST_ROOT/stage/lib/ -lboost_regex

当您要运用多少个库源于贰个路线时使用办法B就节省了(paid
off)。注意到方式B中并从未钦赐.a(静态库)还中.so(动态库),系统将机关地帮您选用选择静态库依旧动态库,当然你能够透过选项“-static”显示地钦赐。

陆.一库文件的命名格局

拿libboost_regex-gcc34-mt-d-1_36来说:

lib………………………………通用前缀

boost_regex…………………库名

gcc34………………………….编写翻译时使用的toolset是gcc-三.4

mt……………………………..编译时是永葆多线程的

d/s/g/y/p……………………..ABI tag

1_36…………………………..Tag version

六.二运维我们的次第

  首先新建2个文件文件mail.txt

view sourceprint?

To: George Shmidlap

From: Rita Marlowe

Subject: Will Success Spoil Rock Hunter?


See subject.

一旦大家的程序链接到了2个共享动态库,大家要求让系统理解到何处去加载它。请看笔者的~/.bashrc文件:

view sourceprint?

#boost

export BOOST_ROOT=”/usr/local/boost_1_46_1″

export
LD_LIBRARY_PATH=”/usr/local/boost_1_46_1/stage/lib:$LD_LIBRARY_PATH”

运行程序:./example  <  mail.txt

有道是出口

view sourceprint?

Will Success Spoil Rock Hunter?

金沙注册送58 , 得到boost boost分布
只需求头文件的库 使用boost建立多少个简单易行的顺序 准备利用boost二进制文件库
把你的程序链接…

相关文章

网站地图xml地图