• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            編譯Boost——Linux

            相對于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中。這些完成之后,記得要使用ldconfig來更新動態鏈接庫。

            在測試兩個例子之前,我們先設置幾個環境變量。

            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)

            posted on 2007-08-21 11:42 楊粼波 閱讀(13449) 評論(2)  編輯 收藏 引用

            評論

            # re: 編譯Boost——Linux 2008-12-01 19:26 tayoto

            厲害  回復  更多評論   

            # re: 編譯Boost——Linux 2010-06-10 18:01 cgx

            @tayoto
            學習了,謝謝  回復  更多評論   

            国内精品久久久人妻中文字幕| 伊人久久大香线蕉综合热线| 久久99国产一区二区三区| 久久久久久久久无码精品亚洲日韩| 国产香蕉久久精品综合网| 久久久久亚洲AV无码专区网站| 久久精品国产亚洲麻豆| 久久久91精品国产一区二区三区| 久久精品人人做人人爽电影蜜月| 久久久国产精华液| 欧美噜噜久久久XXX| 色综合久久久久无码专区| 久久久久亚洲精品日久生情| 久久中文字幕精品| 亚洲精品无码专区久久久| 欧美牲交A欧牲交aⅴ久久| 国产精品久久久久影院嫩草| 久久免费视频观看| 久久久久久久久久久免费精品| 亚洲精品无码专区久久同性男| 色狠狠久久综合网| 久久午夜伦鲁片免费无码| 狠狠色丁香久久婷婷综| 99久久伊人精品综合观看| 亚洲国产成人久久一区久久| 99精品国产综合久久久久五月天 | 99久久99久久精品国产片| 精品久久久久久国产三级| 亚洲精品99久久久久中文字幕 | 2021国产精品久久精品| 亚洲αv久久久噜噜噜噜噜| 91久久香蕉国产熟女线看| 一本色道久久综合| 久久亚洲高清观看| 久久这里都是精品| 国内精品久久久久久久影视麻豆| 一本色道久久88综合日韩精品 | 国产精品久久久福利| 香蕉99久久国产综合精品宅男自 | 久久人妻AV中文字幕| 国产精品久久久99|