• <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>

            舞影凌亂

            專注C/C++,Linux

            統(tǒng)計(jì)

            留言簿(1)

            積分與排名

            Linux好站點(diǎn)

            Oracle

            閱讀排行榜

            評(píng)論排行榜

            boost庫(kù)linux編譯安裝

                相對(duì)于Windows來(lái),Linux下的boost編譯簡(jiǎn)單至極。沒(méi)有那么多的可選編譯器,沒(méi)有那長(zhǎng)的編譯時(shí)間,沒(méi)有那么多的硬盤使用量,統(tǒng)一的inlude和lib目錄,你熟悉命令行,不使用IDE,不需要我那么羅嗦的介紹怎么配置EditPlus。

            首先是下載boost,可以在此
            http://sourceforge.net/projects/boost
            尋找一個(gè)合適的版本。比如我下載的是boost_1_33_1.tar.gz,解壓到/opt。

            tar xzvf boost_1_33_1.tar.gz -C/opt

            提醒:做這些事情的時(shí)候你需要有root權(quán)限。

            進(jìn)入boost目錄:

            cd /opt/boost_1_33_1

            首先我們要編譯bjam:

            cd tools/build/jam_src/
            ./build.sh

            很快編譯結(jié)束,默認(rèn)情況下,bjam會(huì)被復(fù)制到/usr/local/bin/bjam。

            現(xiàn)在你可以使用bjam編譯boost了。

            cd ../../..
            bjam -sTOOLS=gcc install

            編譯時(shí)間不會(huì)如windows那么長(zhǎng)久,在我的電腦上編譯了大約40分鐘。你可以在前后使用df命令檢查下磁盤使用,在我的電腦上,編譯boost花費(fèi)了500M的空間。

            使用install會(huì)把頭文件復(fù)制到/usr/local/include/boost-1_33_1中,把生成的lib復(fù)制到/usr/local/lib中。這些完成之后,記得要使用ldconfig來(lái)更新動(dòng)態(tài)鏈接庫(kù)。

            在測(cè)試兩個(gè)例子之前,我們先設(shè)置幾個(gè)環(huán)境變量。

            BOOST_ROOT=/opt/boost_1_33_1
            BOOST_INCLUDE=/usr/local/include/boost-1_33_1
            BOOST_LIB=/usr/local/lib

            為了使其能夠在登錄時(shí)自動(dòng)導(dǎo)入,你可以寫一個(gè)腳本:
            #!/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設(shè)置執(zhí)行權(quán)限。

            現(xiàn)在我們可以寫兩段代碼來(lái)測(cè)試了。

            第一個(gè)測(cè)試文件是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

            運(yùn)行:
            ./lex

            輸出:
            123
            123.12

            你可以將$BOOST_ROOT改為$BOOST_INCLUDE,如果你沒(méi)有設(shè)置環(huán)境變量,可以改為/opt/boost_1_33_1或者/usr/local/include/boost-1_33_1。

            我們的第二個(gè)例子是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

            運(yùn)行:
            ./re

            輸出:
            who
            lives
            in
            a
            pineapple
            under
            the
            sea?

            這里要使用-l指定了鏈接庫(kù)。

            現(xiàn)在boost的基本安裝配置已經(jīng)完成,但是我們可以再改進(jìn)下。

            如果不想每次都指定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

            這個(gè)命令會(huì)清除編譯時(shí)的中間文件,/usr/local/lib下帶版本號(hào)的boost libs,和/usr/local/include下的boost頭文件。但是同時(shí)節(jié)省了幾百M(fèi)的硬盤空間。

            所以如果你使用了clean,記得將BOOST_INCLUDE更為BOOST_ROOT(/opt/boost_1_33_1),將 /usr/include/boost link到/opt/boost_1_33_1/boost,再有就是編譯鏈接時(shí)的boost lib不要帶版本號(hào)。

            如果你覺(jué)得編譯時(shí)手動(dòng)鏈接敲那么長(zhǎng)的名字比較麻煩,可以使用腳本來(lái)自動(dòng)尋找鏈接:

            #!/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)

            將這段代碼寫進(jìn)/usr/local/bin/gccboost,賦予執(zhí)行權(quán)限。

            使用方法:
            gccboost lex.cpp
            gccboost re.cpp

            注意:使用此命令假設(shè)boost頭文件在/usr/include中,如果假設(shè)不成立,請(qǐng)自行修改腳本此行:
            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環(huán)境變量不存在,修改下面兩行代碼:
            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將會(huì)自動(dòng)修改輸出的文件名為*.cpp的文件名(如lex.cpp將輸出lex),如果不需要,請(qǐng)將下面的代碼:
            cmd = 'g++ %s %s -o %s' % (' '.join(files), libline, obj)

            改為:
            cmd = 'g++ %s %s' % (' '.join(files), libline)


            Boost安裝歷程至此基本結(jié)束。

            posted on 2010-06-01 23:36 幽夢(mèng)新影 閱讀(7549) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C/C++基礎(chǔ)知識(shí)Linux

            国产精品久久久久久| 一本久久精品一区二区| 国产精品久久久天天影视| 亚洲国产精品婷婷久久| 亚洲精品国产第一综合99久久| 久久综合亚洲色HEZYO社区| 久久精品麻豆日日躁夜夜躁| 777久久精品一区二区三区无码| 久久综合久久鬼色| 久久99久久99小草精品免视看| 色婷婷久久久SWAG精品| 久久国产亚洲高清观看| 亚洲精品乱码久久久久久不卡| 久久精品一区二区| 无码国内精品久久人妻蜜桃| 久久性生大片免费观看性| 精品久久久久久久久中文字幕| 精品国产99久久久久久麻豆| 国产AⅤ精品一区二区三区久久| 人妻丰满AV无码久久不卡| 久久99精品久久久久久不卡| 精品国产VA久久久久久久冰| 久久精品久久久久观看99水蜜桃| 久久国产精品波多野结衣AV | 久久狠狠爱亚洲综合影院 | 亚洲一区精品伊人久久伊人 | 久久久www免费人成精品| 久久久中文字幕日本| 久久成人精品视频| 国内精品久久久久伊人av | 91精品国产综合久久久久久 | 国产精品伊人久久伊人电影 | 久久99精品国产麻豆不卡| 免费国产99久久久香蕉| 久久99中文字幕久久| 久久久久四虎国产精品| 51久久夜色精品国产| 久久精品国产一区二区| 一级a性色生活片久久无少妇一级婬片免费放 | 久久亚洲国产成人精品性色| 亚洲AV日韩AV永久无码久久|