• <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變量中

             ?。?)編譯程序時如果用到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的生成安裝步驟:

             ?。?)cd $BOOST_ROOT/tools/build/v2

             ?。?)./bootstrap.sh

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

             ?。?)把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 多彩人生 閱讀(8186) 評論(0)  編輯 收藏 引用 所屬分類: ubuntu

            導航

            統計

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            91精品国产乱码久久久久久| 2021少妇久久久久久久久久| 久久高清一级毛片| 久久精品国产清自在天天线| 狠狠精品久久久无码中文字幕 | 一本色综合网久久| 久久久WWW成人免费毛片| 久久一区二区三区免费| 婷婷综合久久中文字幕蜜桃三电影| 久久综合九色综合久99| 久久精品国产一区二区电影| 国产精品亚洲综合久久| 久久精品男人影院| 欧美精品九九99久久在观看| 国产成人久久精品激情| 亚洲欧洲中文日韩久久AV乱码| 亚洲国产精品久久久久婷婷软件 | 久久婷婷五月综合97色一本一本 | 曰曰摸天天摸人人看久久久| 久久精品国产只有精品66| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久夜色精品国产噜噜噜亚洲AV| 国产午夜久久影院| 亚洲伊人久久成综合人影院 | 久久久久无码精品国产| 精品久久久久久无码国产| 狠狠综合久久AV一区二区三区| 热99re久久国超精品首页| 精品国产99久久久久久麻豆 | 久久A级毛片免费观看| 三级韩国一区久久二区综合 | 国产国产成人精品久久| 婷婷久久综合| 久久亚洲av无码精品浪潮| 久久激情五月丁香伊人| 2021久久精品国产99国产精品| 久久久WWW成人免费精品| 国产精品成人精品久久久| 久久精品国产秦先生| 中文字幕热久久久久久久| 亚洲Av无码国产情品久久|