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

            colorful

            zc qq:1337220912

             

            boost 安裝 ubuntu下

            最近在研究hadoop和云計算,但是hadoop是java寫的,在hadoop上編寫程序也要用java,所以最近可能會經常使用java。為了防止忘記C++,今天決定開始研究一下boost庫。

            先把boost裝到ubuntu吧。

            下載boost_1_43_0.tar.gz到/home/dtz/下,解壓 tar zxvf boost_1_43_0.tar.gz
            cd boost_1_43_0,

            執行:

            sudo ./bootstrap.sh 

            sudo ./bjam install

            這樣boost庫就安裝好了

            http://www.codesky.net/article/201108/133806.html

            //test.cpp
            #include <boost/asio.hpp>
            int main()
            {
                return 0;
            }

            編譯:

            方法A:g++  -I/usr/local/include/boost/  test.cpp -o test  /usr/local/lib/ -lboost_thread.a -lboost_system.a -lpthread

            方法B:g++  -I/usr/local/include/boost/  test.cpp -o test  -L/usr/local/lib/ -lboost_thread -lboost_system -lpthread


             

            當你要使用多個庫源于一個路徑時使用方法B就省力了(paid off)。注意到方法B中并沒有指定.a(靜態庫)還中.so(動態庫),系統將自動地幫你選擇使用靜態庫還是動態庫,當然你可以通過選項“-static"顯示地指定。


            -----------------------------------------------------------------------

            Linux上安裝使用boost入門指導

            獲得boost

            boost分布

            只需要頭文件的庫

            使用boost建立一個簡單的程序

            準備使用boost二進制文件庫

            把你的程序鏈接到boost庫

            1.獲得boost

            下載boost_1_46_1.tar.bz2

            解壓

            2.boost分布

            boost_1_46_1.........................boost根目錄

              boost/.....................................所有boost頭文件

              libs/........................................Tests,.cpps,docs等的庫文件

            注意:

              (1)boost根目錄(通常是/usr/local/boost_1_46_1)想到$BOOST_ROOT變量中

              (2)編譯程序時如果用到boost庫,需要指定頭文件路徑-I$BOOST_ROOT

              (3)因為所有頭文件都在boost文件夾下,并且頭文件都是hpp后綴,所#include形如:

                #include <boost/whaever.hpp>

            3.只需要頭文件的庫

              絕大多數的boost庫都是header-noly的:它們完全由包含模板和inline函數的頭文件組成,不需要單獨編譯和二進制庫文件,也不需要鏈接時特別對待。

              只有下面的boost庫必需單獨built:

            Boost.Filesystem

            Boost.GraphParallel

            Boost.IOStreams

            Boost.MPI

            Boost.ProgramOptions

            Boost.Python (see the Boost.Python build documentation before building and installing it)

            Boost.Regex

            Boost.Serialization

            Boost.Signals

            Boost.System

            Boost.Thread

            Boost.Wave

              下面這些單獨built是可選(optional)的: 

              Boost.DateTime  Boost.Graph  Boost.Math  Boost.Random  Boost.Test

            4.使用boost建立簡單的程序

              下面的程序(example.cc)只用到header-only庫。它是從標準輸入中讀入一串整數,使用Boost.Lambda每個數乘以3后輸出。

            view sourceprint?

            #include <boost/lambda/lambda.hpp>

            #include <iostream>

            #include <iterator>

            #include <algorithm>

             

            int main()

            {

                using namespace boost::lambda;

                typedef std::istream_iterator<int> in;

             

                std::for_each(

                    in(std::cin), in(), std::cout << (_1 * 3) << " " );

            }

            編譯:g++  -I$BOOST_ROOT  example.cc  -o  example

            運行:echo 1 2 3 | ./example

            5.準備使用boost二進制庫

              如果你的程序用到需要單獨編譯的boost庫,你需要首先獲得這些二進制庫文件。

            5.1編譯安裝所有二進制庫文件

              cd $BOOST_ROOT

              ./bootstrap.sh  --help

              ./bootstrap.sh  --prefix=/usr/local    ##其實默認情況下prefix的值就是/usr/local

              此時生成了bjam可執行文件,這個東西就是用來編譯boost庫的。

              ./bjam  install

            5.2僅安裝指定的二進制庫文件

              下面均使用系統默認的編譯器,即Linux上的gcc。

              5.2.1安裝Boost.build

              Boost.Build是一個用于開發、測試、安裝軟件的基于文本的系統。Boost.Build的生成安裝步驟:

              (1)cd $BOOST_ROOT/tools/build/v2

              (2)./bootstrap.sh

              (3)./bjam  install  --prefix=/usr/local/      ##prefix是Boost.Build安裝位置

              (4)把prefix/bin放到PATH中          ##當然/usr/local/bin已經PATH中了

              5.2.2調用bjam時不指定toolset則使用系統默認的編譯器。如果你的Linux上裝了不同版本的gcc,則使用toolset選項時可以指定版本號:toolset=gcc-4.4

              5.2.3指定build路徑,通過--build-dir=/path選項,不指定時默認在當前路徑下創建bin.v2文件夾,把生成的文件放在其內。

              5.2.4調用bjam

              cd  $BOOST_ROOT

              bjam  --build-dir=./build-boost  toolset=gcc   stage

              上面的命令將創建static and shared non-debug multi-threaded variants of the libraries.如果要建立所有的variants,請使用"--build-type=complete"選項。

              所有的boost二進制庫文件將放在stage/lib/下,如果你要另外指定路徑,請使用“--stagedir=directory"選項。

              注意為節省build時間,你可能需要少build一些庫文件:

            查看庫文件名稱  --show-libraries

            限制build哪些庫  --with-libraryname或者--without-libraryname

            選擇特定的build variant  adding release or debug to the command line

              友情提示:Boost.Build會生成很多報告輸出,如果你能保證建立過程不出錯誤,你可以禁止這些輸出以節省時間。方法:在命令后追加”>build.log  2>&1"

            6.把你的程序鏈接到boost庫

              下面的程序是從郵件中抽取“主題”內容,它用到了Boost.Regex庫,這個庫是需要單獨編譯的。

            view sourceprint?

            #include <boost/regex.hpp>

            #include <iostream>

            #include <string>

             

            int main()

            {

                std::string line;

                boost::regex pat( "^Subject: (Re: |Aw: )*(.*)" );

                

                while (std::cin)

                {

                    std::getline(std::cin, line);

                    boost::smatch matches;

                    if (boost::regex_match(line, matches, pat))

                        std::cout << matches[2] << std::endl;

                }

            }

            編譯:

            方法A:g++  -I$BOOST_ROOT  example.cc -o example  $BOOST_ROOT/stage/lib/ -lboost_regex.a

            方法B:g++  -I$BOOST_ROOT  example.cc -o example  -L$BOOST_ROOT/stage/lib/ -lboost_regex

            當你要使用多個庫源于一個路徑時使用方法B就省力了(paid off)。注意到方法B中并沒有指定.a(靜態庫)還中.so(動態庫),系統將自動地幫你選擇使用靜態庫還是動態庫,當然你可以通過選項“-static"顯示地指定。

            6.1庫文件的命名方式

            拿libboost_regex-gcc34-mt-d-1_36來說:

            lib....................................通用前綴

            boost_regex.....................庫名

            gcc34...............................編譯時使用的toolset是gcc-3.4

            mt...................................編譯時是支持多線程的

            d/s/g/y/p..........................ABI tag

            1_36................................Tag version

            6.2運行我們的程序

              首先新建一個文本文件mail.txt

            view sourceprint?

            To: George Shmidlap

            From: Rita Marlowe

            Subject: Will Success Spoil Rock Hunter?

            ---

            See subject.

            如果我們的程序鏈接到了一個共享動態庫,我們需要讓系統知道到哪兒去加載它。請看我的~/.bashrc文件:

            view sourceprint?

            #boost

            export BOOST_ROOT="/usr/local/boost_1_46_1"

            export LD_LIBRARY_PATH="/usr/local/boost_1_46_1/stage/lib:$LD_LIBRARY_PATH"

            運行程序:./example  <  mail.txt

            應該輸出

            view sourceprint?

            Will Success Spoil Rock Hunter?


             

            posted on 2012-05-02 09:49 多彩人生 閱讀(8180) 評論(0)  編輯 收藏 引用 所屬分類: ubuntu

            導航

            統計

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品视频网| 亚洲精品乱码久久久久久蜜桃图片| 久久精品国产99国产电影网| 久久久久久狠狠丁香| 久久久精品日本一区二区三区 | 国产精品久久国产精品99盘 | 伊人久久大香线蕉综合影院首页| 波多野结衣AV无码久久一区| 一级做a爰片久久毛片16| 久久性生大片免费观看性| 国产aⅴ激情无码久久| 国产精品伊人久久伊人电影| 亚洲AV无一区二区三区久久 | 99热精品久久只有精品| 亚洲AV乱码久久精品蜜桃| 久久国产福利免费| 久久青青草原精品影院| 99久久国产宗和精品1上映 | 97久久精品无码一区二区| 色播久久人人爽人人爽人人片AV| 久久精品国产亚洲沈樵| 久久久久亚洲AV片无码下载蜜桃| 亚洲国产视频久久| 久久久久久国产a免费观看不卡| 久久国产高潮流白浆免费观看| 久久影视综合亚洲| 久久精品成人欧美大片| 久久免费小视频| 四虎国产永久免费久久| 久久精品欧美日韩精品| 97精品国产97久久久久久免费 | 国产V综合V亚洲欧美久久| 亚洲va久久久噜噜噜久久男同| 久久大香萑太香蕉av| 久久久国产亚洲精品| 女人高潮久久久叫人喷水| 亚洲人成无码www久久久| 亚洲精品国产综合久久一线| 欧美一级久久久久久久大| 国产精品99久久久久久人| 久久久久久久97|