您的位置:首页 > 运维架构 > Linux

linux/mac平台上编译安装boost库

2014-11-10 18:52 106 查看
1.Boost库的下载地址:http://sourceforge.net/projects/boost/files/boost/1.44.0/

2.Boost库的编译,安装

下载boost_1_44_0.tar.gz

tar -zxvf boost_1_44_0.tar.gz

然后进入解压缩后的文件夹编译boost的编译器jam

cd boost_1_44_0\tools\jam

./build_dist.sh

编译完后在这个目录下有编译出的bjam文件

boost_1_44_0\tools\jam\stage\bin.linuxx86

把它copy到boost_1_44_0 然后在这个目录下运行命令编译:

./bjam "-sTOOLS=gcc" "--includedir=/usr/include" "--libdir=/usr/lib/boost" install

./bjam --toolset=gcc --includedir=/usr/local/include --libdir=/usr/local/lib/boost install

开始编译,等待编译完成,需很长时间。

关于bjam的后面的参数的设置:

-sTOOLS=gcc 指定编译器为GCC

--includedir=/usr/include/ 指定头文件的安装目录,我安装在/usr/include下。如果安装成功,将在/usr/include/生成目录boost_1_33,该目录下就是boost的头文件目录

--libdir=/usr/lib/boost 指定boost的库文件的存放位置, 生成的 .a .so 文件将放在该目录下

install 编译并安装boost

3.注意事项

安装完成后,为了每次使用时不用输入太多的目录,可以在/etc/profile中加入:

BOOST_INCLUDE=/usr/include/boost

BOOST_LIB=/usr/lib/boost

export BOOST_INCLUDE BOOST_LIB

以后在编译程序时,只需要用:-I$BOOST_INCLUDE -L$BOOST_LIB 即可,还要使用-l指定了链接库。

也许会出现编译时或者运行时找不到动态库(*.so)的错误

把/usr/lib/boost追加到动态链接库配置文件/etc/ld.so.conf中,然后直接运行ldconfig,即可!

{仅测试成功一次的方式:./bjam --toolset

lib:/newdisk/hotevent/boost_1_44_0/stage/lib

include:/newdisk/hotevent/boost_1_44_0

ln -s /newdisk/hotevent/boost_1_44_0 /usr/include/boost

并把/newdisk/hotevent/boost_1_44_0/stage/lib加入到/etc/ld.so.conf,用命令ldconfig更新一下。

在编译程序时直接用g++ re.cpp -lboost_regex -o re即可!}

4.Boost库的使用举例

第一个测试文件是lex.cpp:

#include <boost/lexical_cast.hpp>

#include <iostream>

int main()

{

using boost::lexical_cast;

int a = lexical_cast<int>("123");

double b = lexical_cast<double>("123.12");

std::cout<<a<<std::endl;

std::cout<<b<<std::endl;

return 0;

}编译:g++ lex.cpp -I$BOOST_INCLUDE -o lex

运行:./lex

输出:

123

123.12

我们的第二个例子是re.cpp:

#include <iostream>

#include <string>

#include <boost/regex.hpp>

int main() {

std::string s = "who,lives:in-a,pineapple under the sea?";

boost::regex re(",|:|-|\\s+");

boost::sregex_token_iterator

p(s.begin( ), s.end( ), re, -1);

boost::sregex_token_iterator end;

while (p != end)

std::cout << *p++ << '\n';

}编译:g++ re.cpp -I$BOOST_INCLUDE -lboost_regex -o re运行:./re输出:

who

lives

in

a

pineapple

under

the

sea?

附注:为了让动态链接库为系统所共享,还需运行动态链接库的管理命令 -- ldconfig

ldconfig 命令的用途,主要是在默认搜寻目录(/lib和/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下,搜索出可共享的动态 链接库(格式如前介绍,lib*.so*),进而创建出动态装入程序(ld.so)所需的连接和缓存文件.缓存文件默认为 /etc/ld.so.cache,此文件保存已排好序的动态链接库名字列表.

ldconfig的使用(这个很重要,我就是在这个问题上耗了很多时间)详解Linux动态库被系统共享的三种办法

linux共享库位置配置(LD_LIBRARY_PATH环境变量 或者 更改/etc/ld.so.conf 或者 使用-R选项)

安装过程参考的博文:linux下安装boost ,boost库linux编译安装,Linux中安装boost库详解

Boost下载安装编译配置使用指南(含Windows和Linux)

Boost编译

Boost主页:http://www.boost.org/

环境:Ubuntu LTS 10.04, 64bit

GCC版本:

#gcc --version

gcc (Ubuntu 4.4.3-4ubuntu5) 4.4.3

Copyright (C) 2009 Free Software Foundation, Inc.

This is free software; see the source for copying conditions. There is NO

warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

#

适用版本(适用版本只用于记录本次编译测试所使用的版本,不代表只能适用此版本):boost_1_49_0.tar.gz

说明:Boost的编译系统是使用其自带的bjam工具,所以和一般的编译的过程不太一样。

编译过程:

1. 解压、创建prefix目录

tar zxvf boost_1_49_0.tar.gz
mv boost_1_49_0 gcc_boost_1_49_0
cd gcc_boost_1_49_0
mkdir prefix

2. 关于boost
Boost文件夹,这里面是Boost的源码。其余的libs、doc、tools、more等等里面都主要是文档,当然,tools里面可能还有b2(bjam,boost的编译工具)的源码。

主目录下的index.html就可以打开boost的文档,里面可以链接到上面各个文档中。

PS:这里的boost文档,并非编译后的boost库的API文档什么的,由于Boost项目比较大,所以提供了很多文档,包括介绍如何编译等等的。总之,这点很好。

bootstrap.sh,这个脚本用于进行一些配置,事实上,它还会先编译bjam。总之,这个脚本用于编译bjam工具以及进行一些编译前的配置。

3. 配置

./bootstrap.sh

其输出:

Building Boost.Build engine with toolset gcc... tools/build/v2/engine/bin.linuxx86_64/b2
Detecting Python version... 2.6
Detecting Python root... /usr
Unicode/ICU support for Boost.Regex?... not found.
Generating Boost.Build configuration in project-config.jam...

Bootstrapping is done. To build, run:

./b2

To adjust configuration, edit 'project-config.jam'.
Further information:

- Command line help:
./b2 --help

- Getting started guide: http://www.boost.org/more/getting_started/unix-variants.html
- Boost.Build documentation: http://www.boost.org/boost-build2/doc/html/index.html
可以看到,其编译了boost的编译引擎(bjam/b2)。
会生成一个project-config.jam文件,这个文件可以用于对bjam进行一些配置。当然,还有一些其它可以配置的地方。另外,通过命令行配置也是可以的(PS:个人喜欢用命令行去配置)。

4. 编译

./bjam --prefix=./prefix/ install

bjam的使用:

关于bjam的文档,可以参考:boost_1_49_0/doc/html/bbv2/overview.html,由于bjam可以有几种配置的地方,下面的内容只说明如何在命令行对bjam编译进行配置。

1. bjam的调用(boost_1_49_0/doc/html/bbv2/overview.html#bbv2.overview.invocation)

要调用Boost.build来编译,只需要使用bjam命令即可。bjam可以接受三种类型的tokens,而且顺序不限。分别是:选项(options)、属性(properties)、目标(target)。

PS:由于对于一般的命令行,可执行程序后面的部分,有时候我们都称之为“选项”。这里,将其分为了三个类型,那么下面的内容,提到选项,就是表示bjam的options的概念。

2. 选项(boost_1_49_0/doc/html/bbv2/overview.html#bbv2.overview.invocation.options):

选项一般以破折号(dash)或者双破折号开始。下面是一些标准选项,但是,每个不同的工程可以增加额外的一些选项:

--help

帮助

--clean

清除所有targets。与make中的clean不同的是,可以同时使用--clean和target names来清除指定的目标。

--clean-all

清除

--build-dir

指定编译的临时文件的存放目录

--version

显示版本

-a

使得所有文件重新编译

-n

不执行命令,只是显示之(用于调试自己的设置选项是否被正确使用是比较合适的。)

-q

在遇到第一个错误就停止,而不是继续编译其它不依赖这个错误的targets

-j N

并行执行命令数

--debug-configuration

--debug-building

--debug-generators

--ignore-config

-d0

-d N

-d +N

都和debug(编译的debug)信息有关。用于控制输出哪些信息。

-o file

将更新操作写入指定的文件,而不运行它们。

-s var=value

为jam设置全局变量。

3. 属性(boost_1_49_0/doc/html/bbv2/overview.html#bbv2.overview.invocation.properties):

属性的形式为“feature=value”。

下面是常见的features(完整的features参考相关文档):



toolset配置,可以参考:pl_Boost/boost_1_49_0/doc/html/bbv2/reference.html#bbv2.reference.tools.compilers

4. 目标(boost_1_49_0/doc/html/bbv2/overview.html#bbv2.overview.invocation.targets):

和make中的target的理解应该是类似的,就是指定要编译哪些target了,所以和“输入”配置文件有关。

Mac OS X中安装使用Boost库
在mac下,Xcode中建立的C++项目只包含STL库,如果要使用Boost库,需要进行安装以及导入。

这里使用MacPorts来安装Boost,MacPorts是一个开源项目,其中集成了许多Mac系统常用的开源软件的自动安装,用来代替传统的命令行安装,简单易用。

首先从MacPorts官网上下载最新版本,非常小。解压后是一个dmg镜像,打开里面的pkg程序,出现安装界面。

安装完毕后打开终端,输入sudo port install boost,软件就会自动下载安装Boost库,注意此处需要root权限。

需要挺长一段时间,网速慢的建议不要干等了。安装好后,Xcode的项目中还是找不到Boost,这是因为还没有将Boost的路径导入进去。

打开Xcode的菜单栏Project/Edit Project Setting的对话框,在Build标签里找到其中的Header Search Paths一栏,增加一个目录,填入/opt/local/include,然后找到Library Search Paths一栏,填入/opt/local/lib,这样就能正常调用Boost库了,试写代码:

#include <Boost/asio.hpp>

编译通过,大功告成!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: