c++库之boost库

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 -build.jam等文件,有时候bjam在boost _1_33_1/下


现在你可以使用bjam编译boost 了。

cd ../../..

bjam "

-sTOOLS=gcc"

 install




编译时间不会如windows那么长久,在我的电脑上编译了大约40分钟。你可以在前后使用df命令检查下磁盘使用,在我的电脑上,编译 boost 花费了500M的空间。

使用install会把头文件复制到/usr/local/include/ boost -1_33_1中,把生成的lib复制到/usr/local/lib中。
这些完成之后,记得要使用ldconfig来更新动态链接库,动态链接库路径的配置文件在
/etc/ld.so.conf 中。有的时候编译能够成功,但是运行时连接不到库,就是因为路径没有设对或者没有ldconfig。

另外:linux 静态链接库一般以.a结尾,动态链接库以.so结尾,分别对应于windows下的.lib与.dll。

在测试两个例子之前,我们先设置几个环境变量。

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 / lib
  export 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)

你可能感兴趣的:(c++库之boost库)