boost庫linux編譯安裝

出處:http://blog.sciencenet.cn/blog-323317-674123.html

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 -IBOOSTROOT−olex運行:./lex輸出:123123.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 -IBOOST_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*#includes*<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)

Boost安裝歷程至此基本結束。

未經允許不得轉載:GoMCU » boost庫linux編譯安裝