C++ Boost庫的編譯及使用

https://www.jianshu.com/p/de1fda741bebhtml

https://www.cnblogs.com/weizhixiang/p/5804778.htmlpython

Windows編譯


生成boost的自用的編譯工具bjam.exe

解壓後,使用Visual Studio 編譯。首先打開「Developer Command」,cd到boost解壓後的根目錄:
cd X:\boost_X_XX_Xlinux

執行bootstrap.bat,會在boost根目錄生成 b2.exe 、bjam.exe 、project-config.jam 、bootstrap.log四個文件。其中,b2.exe 、bjam.exe 這兩個exe做用是同樣的,bjam.exe 是老版本,b2是bjam的升級版本。ios

使用bjam(或b2)來編譯boost

bjam命令參數分析
如下面的命令做爲示例來分析各個參數的做用
bjam stage --toolset=msvc-14.0 --without-python --stagedir="X:\boost\vc14" link=static runtime-link=shared runtime-link=static threading=multi debug releasebootstrap

  1. stage/install:
    stage表示只生成庫(dll和lib),install還會生成包含頭文件的include目錄。推薦使用stage,由於install生成的這個include目錄實際就是boost安裝包解壓縮後的boost目錄(X:\boost_X_XX_X\boost,只比include目錄多幾個非hpp文件,都很小),因此能夠直接使用,並且不一樣的IDE均可以使用同一套頭文件,這樣既節省編譯時間,也節省硬盤空間。windows

  2. toolset:
    指定編譯器,可選的如borland、gcc、msvc(VC6)、msvc-12.0(VS2013)、msvc-14.0(VS2015)等。多線程

  3. without/with:
    選擇不編譯/編譯哪些庫。由於python、mpi等庫我都用不着,因此排除之。還有wave、graph、math、regex、test、program_options、serialization、signals這幾個庫編出的靜態lib都很是大,因此不須要的也能夠without。這能夠根據各人須要進行選擇,默認是所有編譯。可是須要注意,若是選擇編譯python的話,是須要python語言支持的,能夠到python官方主頁下載安裝。
    查看boost包含庫的命令是bjam --show-libraries。工具

  4. stagedir/prefix:
    stage時使用stagedir,install時使用prefix,表示編譯生成文件的路徑。推薦給不一樣的IDE指定不一樣的目錄,如VS2015對應的是post

X:\boost_X_XX_X\vc14測試

若是使用了install參數,那麼還將生成頭文件目錄,vc14對應的就是

X:\boost_X_XX_X\boost\bin\vc14\include\boost_X_XX_X\boost

  1. build-dir:
    編譯生成的中間文件的路徑。這個本人這裏沒用到,默認就在根目錄(X:\boost_X_XX_X\boost)下,目錄名爲bin.v2,等編譯完成後可將這個目錄所有刪除(沒用了),因此不須要去設置。

  2. link:
    生成動態連接庫/靜態連接庫。生成動態連接庫需使用shared方式,生成靜態連接庫需使用static方式。通常boost庫可能都是以static方式編譯,由於最終發佈程序帶着boost的dll感受會比較累贅。

  3. runtime-link:
    動態/靜態連接C/C++運行時庫。一樣有shared和static兩種方式,這樣runtime-link和link一共能夠產生4種組合方式,各人能夠根據本身的須要選擇編譯。

  4. threading:
    單/多線程編譯。通常都寫多線程程序,固然要指定multi方式了;若是須要編寫單線程程序,那麼還須要編譯單線程庫,可使用single方式。

  5. debug/release:
    編譯debug/release版本。通常都是程序的debug版本對應庫的debug版本,因此兩個都編譯。

配置


包含頭文件的Include路徑:X:\boost_X_XX_X
包含庫文件的連接路徑:X:\boost_X_XX_X\bin\vc14\lib

  1. 能夠設置爲僅用於當前project:
    選中當前project->Properties->Configuration Properties->C/C++->General: Additional Include Directories: 設置 X:\boost_X_XX_X
    選中當前project->Properties->Configuration Properties->Linker->General: Additional LibraryDirectories: 設置 X:\boost_X_XX_X\bin\vc14\lib

  2. 可設置爲僅用於當前Solution:
    選中當前project->Properties->Configuration Properties->VC++ Directories:
    Include Directories: 設置 X:\boost_X_XX_X
    LibraryDirectories: 設置 X:\boost_X_XX_X\bin\vc14\lib

  3. 可設置爲OS當前用戶下的VC++環境(當前用戶下VC++所建立的全部Solution)
    在某個已打開的工程下,切換到Property Manager 選項卡,而後而後展開當前工程的properties配置,打開Microsoft.Cpp.Win32.User
    選擇Common Properties->VC++ Directories:
    Include Directories: 設置 X:\boost_X_XX_X
    LibraryDirectories: 設置 X:\boost_X_XX_X\bin\vc14\lib
    這樣設置的僅在Win32編譯選項下起做用,x64編譯選項須要另外配置x64的properties sheet。

4.可設置爲OS全部用戶下的VC++環境
能夠編輯 Microsoft.Cpp.Default.props 、Microsoft.Cpp.props 。這裏就不介紹了。

References


 

Linux下編譯使用boost庫:

Boost是什麼很少說, 下面說說怎樣在Linux下編譯使用Boost的全部模塊.

1. 先去Boost官網下載最新的Boost版本, 我下載的是boost_1_56_0版本, 解壓.

2. 進入解壓後目錄: cd boost_1_56_0, 執行下面的命令:

 

$ ./bootstrap.sh --prefix=path/to/installation/prefix

 

prefix的值是你但願安裝boost的路徑, 不開啓此參數的話默認安裝在 /usr/local 下. 我安裝在 /home/xzz/boost_1_56_0目錄下:

 

$ ./bootstrap.sh --prefix=/home/xzz/boost_1_56_0

 

Note: 家目錄不要用 ~ 表示, 編譯腳本不識別 ~, 會在當前目前新建一個名爲 '~' 的目錄.

接着執行:

 

$ ./b2 install

 

這條命令把boost的頭文件文件夾 include/ 安裝在prefix定義的目錄中, 而且會編譯全部的boost模塊, 並將編譯好的庫文件夾 lib/ 也放在prefix定義的目錄中. 全部若是成功編譯的的話, prefix目錄即 /home/xzz/boost_1_56_0目錄應當包含有 include/ 和 lib/ 兩個文件夾.

3. 測試

先測試只依賴頭文件的功能模塊:

將下面的代碼保存爲 test.cpp:

 

[cpp]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. #include <boost/lambda/lambda.hpp>  
  2. #include <iostream>  
  3. #include <iterator>  
  4. #include <algorithm>  
  5.   
  6. int main()  
  7. {  
  8.     using namespace boost::lambda;  
  9.     typedef std::istream_iterator<int> in;  
  10.   
  11.     std::for_each(  
  12.         in(std::cin), in(), std::cout << (_1 * 3) << " " );  
  13. }  

 

編譯

 

$ g++ test.cpp -o test -I /home/xzz/boost_1_56_0/include

-I: 大寫的i, 指定頭文件搜索目錄

執行 ./test 測試, 輸入一個數, 返回這個數乘3的值.

 

 

再測試須要用到二進制庫的功能模塊:

將下面的代碼保存爲 test.cpp:

 

[cpp]  view plain  copy
 
 在CODE上查看代碼片派生到個人代碼片
  1. #include <iostream>  
  2. #include <boost/filesystem.hpp>  
  3.   
  4. using namespace boost::filesystem;  
  5.   
  6. int main(int argc, char *argv[])  
  7. {  
  8.     if (argc < 2) {  
  9.         std::cout << "Usage: tut1 path\n";  
  10.         return 1;  
  11.     }  
  12.     std::cout << argv[1] << " " << file_size(argv[1]) << std::endl;  
  13.     return 0;  
  14. }  


編譯的時候須要注意:

 

 

$ g++ test.cpp -o test -I /home/xzz/boost_1_56_0/include -L /home/xzz/boost_1_56_0/lib -lboost_system -lboost_filesystem

 

 

-L: 後接boost庫文件夾

-l: 這是小寫的 L, 接源文件編譯所需用到的庫文件, 注意使用 -l 要注意, 庫文件之間也存在依賴關係, 好比這裏 boost_filesystem 庫依賴於boost_system 庫, 因此boost_filesystem 要寫在後面, 不然可能會出現符號解析錯誤. 下面是 man g++ 裏的一段話.

引用It makes a difference where in the command you write this option; the linker searches and processes libraries and object files in the order they are specified. Thus, foo.o -lz bar.o searches library z after file foo.o but before bar.o. If bar.o refers to functions in z, those functions may not be loaded.

 

執行 ./test, 這個時候會出現一個問題:

 

./test: error while loading shared libraries: libboost_system.so.1.56.0: cannot open shared object file: No such file or directory

 

 

緣由是在存在動態庫和靜態庫時, gcc優先使用動態庫, 但動態庫在linux下默認搜索路徑是/lib, /usr/lib/usr/local/lib. 因此程序運行的時候出錯. 解決辦法能夠將動態庫拷貝到動態庫的搜索路徑下. 也可使用 -static 參數指定程序使用靜態庫. 這篇博客裏面提供了更多解決方案. 改成使用下面的命令編譯:

 

$ g++ test.cpp -o test -I /home/xzz/boost_1_56_0/include -L -static /home/xzz/boost_1_56_0/lib -lboost_system -lboost_filesystem

 

執行 ./test, 輸出

 

Usage: tut1 path

 

 

 

若是兩個用例都成功編譯了, 那麼恭喜你, boost庫安裝成功.

做者:elivera 連接:https://www.jianshu.com/p/de1fda741beb 來源:簡書 簡書著做權歸做者全部,任何形式的轉載都請聯繫做者得到受權並註明出處。
相關文章
相關標籤/搜索