当你要使用多个库源于一个路径时使用方法B就省力了(paid off)。注意到方法B中并没有指定.a(静态库)还中.so(动态库),系统将自动地帮你选择使用静态库还是动态库,当然你可以通过选项“-static"显示地指定。
Linux上安装使用boost入门指导
获得boost
boost分布
只需要头文件的库
使用boost建立一个简单的程序
准备使用boost二进制文件库
把你的程序链接到boost库
1.获得boost
下载boost_1_46_1.tar.bz2
解压
2.boost分布
boost_1_46_1.........................boost根目录
boost/.....................................所有boost头文件
libs/........................................Tests,.cpps,docs等的库文件
注意:
(1)boost根目录(通常是/usr/local/boost_1_46_1)想到$BOOST_ROOT变量中
(2)编译程序时如果用到boost库,需要指定头文件路径-I$BOOST_ROOT
(3)因为所有头文件都在boost文件夹下,并且头文件都是hpp后缀,所#include形如:
#include <boost/whaever.hpp>
3.只需要头文件的库
绝大多数的boost库都是header-noly的:它们完全由包含模板和inline函数的头文件组成,不需要单独编译和二进制库文件,也不需要链接时特别对待。
只有下面的boost库必需单独built:
Boost.Filesystem
Boost.GraphParallel
Boost.IOStreams
Boost.MPI
Boost.ProgramOptions
Boost.Python (see the Boost.Python build documentation before building and installing it)
Boost.Regex
Boost.Serialization
Boost.Signals
Boost.System
Boost.Thread
Boost.Wave
下面这些单独built是可选(optional)的:
Boost.DateTime Boost.Graph Boost.Math Boost.Random Boost.Test
4.使用boost建立简单的程序
下面的程序(example.cc)只用到header-only库。它是从标准输入中读入一串整数,使用Boost.Lambda每个数乘以3后输出。
view sourceprint?
#include <boost/lambda/lambda.hpp>
#include <iostream>
#include <iterator>
#include <algorithm>
int main()
{
using namespace boost::lambda;
typedef std::istream_iterator<int> in;
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库,你需要首先获得这些二进制库文件。
5.1编译安装所有二进制库文件
cd $BOOST_ROOT
./bootstrap.sh --help
./bootstrap.sh --prefix=/usr/local ##其实默认情况下prefix的值就是/usr/local
此时生成了bjam可执行文件,这个东西就是用来编译boost库的。
./bjam install
5.2仅安装指定的二进制库文件
下面均使用系统默认的编译器,即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.4
5.2.3指定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 2>&1"
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"显示地指定。
6.1库文件的命名方式
拿libboost_regex-gcc34-mt-d-1_36来说:
lib....................................通用前缀
boost_regex.....................库名
gcc34...............................编译时使用的toolset是gcc-3.4
mt...................................编译时是支持多线程的
d/s/g/y/p..........................ABI tag
1_36................................Tag version
6.2运行我们的程序
首先新建一个文本文件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?