Boost 库

Boost 库很不错,所以我今天就安了它一下下。 
Boost 库不是 C++ 标准库的一部分(据说在下一版本的 C++ 标准会采纳它),但它有一些标准库所没有的很有用的一些功能,比如我非常需要的正则表达式( Regular Expression) 。所以我今天就在 GCC 上安装这个东东。(好像 GCC 也自带 Regex 库,我没有太注意) 


先从 Boost .org 上 Download 一个 Boost 版本的 tar.gz 包, boost ×××.tar.gz
然后 tar -zxvf boost ×××.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+x boost .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 #### 下载与安装 为了使用Boost,需先下载并安装该。由于Boost是跨平台的开源项目,支持多种操作系统和编译器组合。对于Windows用户而言,在Visual Studio环境中集成Boost通常涉及几个步骤[^2]。 #### 配置开发环境 以Visual Studio为例,配置过程如下: - 将Boost解压到指定位置; - 在项目的属性页中设置包含路径(Include Directories),指向Boost头文件所在目录; - 设置路径(Library Directories),以便链接静态或动态版本的预构建二进制文件;如果打算自行编译,则还需准备相应的工具链[^3]。 #### 编写代码示例 下面给出一段简单的代码片段来演示如何利用`boost::lambda`实现输入流中的整数乘以三的操作: ```cpp #include <boost/lambda/lambda.hpp> #include <iostream> #include <iterator> #include <algorithm> int main() { using namespace boost::lambda; typedef std::istream_iterator<int> in; // 对于每一个从标准输入读取的整数,将其乘以3后输出 std::for_each(in(std::cin), in(), std::cout << (_1 * 3) << " "); } ``` 这段代码展示了如何通过引入特定命名空间下的宏定义简化表达式的书写方式,从而让程序逻辑更加直观易懂。 #### 加载配置文件实例 当涉及到外部数据源如配置文件,可以借助`boost::property_tree`模块轻松完成解析任务。这里展示了一个基本的例子说明怎样加载INI格式的配置项: ```cpp #include <boost/property_tree/ptree.hpp> #include <boost/property_tree/ini_parser.hpp> // 假设有一个名为config.ini的文件存在当前工作目录下 void load_config(const char* filename){ try{ ptree pt; read_ini(filename, pt); // 访问具体的键值对... } catch (const ptree_error& e){ // 错误处理机制... } } ``` 上述例子中,`read_ini()`函数用于将给定路径处的目标文件内容映射成内存中的树形结构表示形式,便于后续访问其中存储的信息节点[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值