Linux上设置使用boost入门带领,ubuntu下boost编写翻译安装

ubuntu下boost编写翻译安装

boost

安装

环境:Ubuntu 12.04 32bit,boost 1.49

环境:Ubuntu 12.04
32bit,boost 1.49

 

一.凭借安装

  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

三.解压下载文件,例如下载文件在~/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
一.4玖会在当前目录下,生成三个文本bjam和b二,那七个是一致的,

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

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

只要求头文件的库

5.编译并安装boost

编写翻译达成后,进行设置,也正是将头文件和浮动的库,放到钦定的路子(–prefix)下

  1. Linux上设置使用boost入门带领,ubuntu下boost编写翻译安装。./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     #1旦编写翻译出现谬误: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二进制文件库

七.测试安装是不是科学

新建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二,那五个是同1的,所以接下去的步子,能够用那两当中的任意1个来实行。

生成bjam,上述命令可以涵盖种种选项,具体可参看协助文书档案: ./bootstrap.sh
–help。个中–prefix参数,能够指虞诩装路径,若是不带–prefix参数的话(推荐),暗许路径是
/usr/local/include 和
/usr/local/lib,分别存放头文件和各个库。执行到位后,会生成bjam,已经存在的剧本将会被自动备份。注意,boost
一.4九会在当前目录下,生成五个公文bjam和b贰,那多个是同等的,所以接下去的手续,能够用这两当中的任意一个来执行。

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①.4九的通通编译,在小编英特尔® Core™二 Duo CPU T5750 @ 二.00GHz × 二 ,二G
DDSportage贰内部存款和储蓄器的老机子上,使用上述选项,半个小时就基本上了。这些时间是能够承受的。全部编译安装,心境上觉得也爽快些。^_^

注意,那里是整套编写翻译。当然也得以选取只编写翻译一部分,选项
–with-<library>
只编写翻译钦定的库,如输入–with-regex就只编写翻译regex库了。boost一.49的完全编写翻译,在小编英特尔® Core™二 Duo CPU T5750 @ 二.00GHz × 二 ,二G
DD奇骏二内存的老机子上,使用上述选项,半个时辰就大多了。那一个小时是足以承受的。全体编写翻译安装,激情上呼吸系统感染到也舒畅女士些。^_^

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

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

bjam的1对常用的参数,列表如下:

  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)下

编写翻译实现后,进行安装,也正是将头文件和转变的库,放到钦命的路径(–prefix)下

注意:

./b2 install

./b2 install

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

到现在,借使一切顺遂,就到位安装了。写个小程序检查评定下,来自《Boost程序库完全开发指南——深远C++“准”标准库(修订版)》(罗剑锋著,电子工业出版社二〇一一.五)

于今,就算壹切顺遂,就到位安装了。写个小程序检查评定下,来自《Boost程序库完全开发指南——深刻C++“准”标准库(修订版)》(罗剑锋著,电子工业出版社二〇一一.五)

  (二)编写翻译程序时只要用到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>

叁.只供给头文件的库

 

 

  绝大部分的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库。它是从标准输入中读入1串整数,使用Boost.Lambda每个数乘以三后输出。

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

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

读完这段话,应该就知道出错原因了。所以,解决方案便是用上面的一声令下来编写翻译:

{

12.0四 3二bit,boost 一.4玖中期准备: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;

亚洲必赢官网 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

伍.备选选择boost贰进制库

  如若您的主次用到必要独自编写翻译的boost库,你须要首先获得这么些二进制库文件。

伍.一编写翻译安装全数二进制库文件

  cd $BOOST_ROOT

  ./bootstrap.sh  –help

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

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

  ./bjam  install

五.二仅安装钦点的二进制库文件

  下边均运用系统默许的编写翻译器,即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.2.2调用bjam时不内定toolset则动用系统暗中同意的编写翻译器。借使你的Linux上装了不一样版本的gcc,则使用toolset选项时能够钦赐版本号:toolset=gcc-4.四

  五.二.三钦定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 
二>&壹”

6.把你的程序链接到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…………………库名

gcc3四………………………….编写翻译时使用的toolset是gcc-三.四

mt……………………………..编写翻译时是帮助十二线程的

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

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

陆.二运作大家的程序

  首先新建二个文书文件mail.txt

view sourceprint?

To: George Shmidlap

From: Rita Marlowe

Subject: Will Success Spoil Rock Hunter?


See subject.

要是我们的程序链接到了一个共享动态库,我们要求让系统领悟到哪儿去加载它。请看自身的~/.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?

得到boost boost分布
只须要头文件的库 使用boost建立三个简单易行的主次 准备接纳boost二进制文件库
把你的程序链接…

网站地图xml地图