Boost库很不错,所以我今天就安了它一下下。
Boost库不是
C++标准库的一部分(据说在下一版本的
C++标准会采纳它),但它有一些标准库所没有的很有用的一些功能,比如我非常需要的正则表达式(
Regular Expression)
。所以我今天就在GCC
上安装这个东东。(好像GCC
也自带Regex
库,我没有太注意)
先从 Boost .org上
Download一个
Boost版本的
tar.gz包,
boost ×××.tar.gz
然后 tar -zxvfboost ×××.tar.gz解压缩,在当前目录下得到一个
boost ×××文件包
cd
boost ××× 进入该文件包
我要用的 Regex没有编译好,所以需要自己
build
而为了 build,又先得
build一个
jam工具
cd tools/build/jam_src
里面有一个
build.sh 的脚本文件,./build.sh
执行之,
会在内部的目录里生成几个可执行文件(可以
find -name bjam 找),里面有一个bjam
cp bjam /usr/bin
然后进入 boost ×××目录
执行
bjam " -sTOOLS=gcc"install
就可以了
写程序的时候,把相应的 .h文件
include在程序里
别的需要 build的模块同上方法。
Enjoy
Boost !
-------------------------------------------------------------------------------------
相对于Windows来,Linux 下的boost 编译简单至极。没有那么多的可选编译器,没有那长的编译时间,没有那么多的硬盘使用量,统一的inlude和lib目录,你熟悉命令行,不使用IDE,不需要我那么罗嗦的介绍怎么配置EditPlus。
首先是下载boost ,可以在此
http://sourceforge.net/projects/boost寻找一个合适的版本。比如我下载的是boost _1_33_1.tar.gz,解压到/opt。
tar xzvf boost _1_33_1.tar.gz -C/opt
提醒:做这些事情的时候你需要有root权限。
进入boost 目录:
cd /opt/boost _1_33_1
首先我们要编译bjam:
cd tools/build/jam_src/ ./build.sh
很快编译结束,默认情况下,bjam会被复制到/usr/local/bin/bjam。
现在你可以使用bjam编译boost 了。
cd ../../.. bjam " -sTOOLS=gcc" install
编译时间不会如windows那么长久,在我的电脑上编译了大约40分钟。你可以在前后使用df命令检查下磁盘使用,在我的电脑上,编译boost 花费了500M的空间。
使用install会把头文件复制到/usr/local/include/boost -1_33_1中,把生成的lib复制到/usr/local/lib中。
在测试两个例子之前,我们先设置几个环境变量。
BOOST _ROOT=/opt/boost _1_33_1 BOOST _INCLUDE=/usr/local/include/boost -1_33_1 BOOST _LIB=/usr/local/lib
为了使其能够在登录时自动导入,你可以写一个脚本:
#
!/bin/sh#boost settings
BOOST _ROOT=/
opt /
boost _1_33_1
BOOST _INCLUDE=/
usr /
local /include
/ boost
-1_33_1
BOOST _LIB
=/ usr
/local /
libexport BOOST _ROOT BOOST _INCLUDE BOOST _LIB
将其保存为/etc/profile.d/boost .sh,并使用chmod a+xboost .sh设置执行权限。
现在我们可以写两段代码来测试了。
第一个测试文件是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 _ROOT -o lex
运行:
./lex
输出:
123
123.12
你可以将$BOOST _ROOT改为$BOOST _INCLUDE,如果你没有设置环境变量,可以改为/opt/boost _1_33_1或者/usr/local/include/boost
-1_33_1。
我们的第二个例子是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 _ROOT -lboost_regex-gcc -o re
运行:
./re
输出:
who
lives
in
a
pineapple
under
the
sea?
这里要使用-l指定了链接库。
现在boost 的基本安装配置已经完成,但是我们可以再改进下。
如果不想每次都指定boost 头文件目录,可以将其link到/usr/include中:
ln -s /opt/boost _1_33_1/boost /usr/include/boost
或者:
ln -s /usr/local/include/boost -1_33_1/boost /usr/include/boost
如果你依然嫌boost 编译后占用的空间太大,可以在boost 目录下使用bjam clean:
cd /opt/boost
_1_33_1
bjam -sTOOLS=gcc clean
这个命令会清除编译时的中间文件,/usr/local/lib下带版本号的boost libs,和/usr/local/include下的boost 头文件。但是同时节省了几百M的硬盘空间。
所 以如果你使用了clean,记得将BOOST _INCLUDE更为BOOST _ROOT(/opt/boost _1_33_1),将
/usr/include/boost link到/opt/boost _1_33_1/boost ,再有就是编译链接时的boost
lib不要带版本号。
如果你觉得编译时手动链接敲那么长的名字比较麻烦,可以使用脚本来自动寻找链接:
#
!/usr/bin/python
import
os
import
sys
import
re
BOOST _ROOT
= os.getenv('
BOOST _ROOT'
)
BOOST _LIB
= os.getenv('
BOOST _LIB'
)
#
BOOST _ROOT = '/opt/boost _1_33_1'
#BOOST _LIB = '/usr/local/lib'
def
getlibs():
alls =
os.listdir(BOOST _LIB)
libpattern =
re.compile(r'
^libboost_([^-]+)-gcc'
)
libs =
{ }
for
lib in
alls:
m =
libpattern.match(lib)
if
m:
libs[m.group(1
).lower()] =
1
return
libs
pattern =
re.compile(r'
^/s*#include/s*< /s*boost /(.+)/.(h|hpp)/s*>'
)
libs =
getlibs()
libskeys =
libs.keys()
includes =
{ }
ENV =
os.environ
ARGV =
sys.argv[1
:]
files =
ARGV
if
len(files) ==
0:
sys.exit()
for
f in
files:
if
f.lower().endswith('
.cpp '
):
fp =
open(f, '
r '
)
lines =
fp.readlines()
for
ln in
lines:
m =
pattern.match(ln)
if
m:
libname =
m.group(1
).lower()
if
libname in
libskeys:
includes[libname] =
1
libline =
'
'.join(map(
lambda lib:
' -lboost_
' + lib
+'
-gcc ' , includes.keys()))
obj =
ARGV[0]
obj =
obj[:len(obj)-
4 ]
#
cmd = 'g++ %s -I%s %s -o %s' % (' '.join(files), BOOST _ROOT, libline, obj)
cmd
= '
g++ %s %s -o %s
' %
('
'.join(files), libline, obj)
print
cmd
os.system(cmd)
将这段代码写进/usr/local/bin/gccboost,赋予执行权限。
使用方法:
gccboost lex.cpp
gccboost re.cpp
注意:使用此命令假设boost 头文件在/usr/include中,如果假设不成立,请自行修改脚本此行:
cmd = 'g++ %s %s -o %s' % (' '.join(files), libline, obj)
为之前的注释行:
cmd = 'g++ %s -I%s %s -o %s' % (' '.join(files), BOOST
_ROOT, libline, obj)
如若BOOST _ROOT和BOOST _LIB环境变量不存在,修改下面两行代码:
BOOST
_ROOT = os.getenv('BOOST
_ROOT')
BOOST
_LIB = os.getenv('BOOST
_LIB')
为之后注释行:
BOOST
_ROOT = '/opt/boost
_1_33_1'
BOOST
_LIB = '/usr/local/lib'
另外,gccboost将会自动修改输出的文件名为*.cpp的文件名(如lex.cpp将输出lex),如果不需要,请将下面的代码:
cmd = 'g++ %s %s -o %s' % (' '.join(files), libline, obj)
改为:
cmd = 'g++ %s %s' % (' '.join(files), libline)
5798

被折叠的 条评论
为什么被折叠?



