VS2019下安装boost C++库
Boost C++库的下载安装
-
选择合适的版本下载,这里下载了
boost_1_73_0.7z
-
解压即为你的安装目录
-
解压完后,你会看到你的目录下有bootstrap.bat批处理文件,双击执行
-
运行完成后会在目录下得到b2.exe文件,可以产生lib文件,运行会比较长久
-
运行完成后,在
stage/lib/
目录下会产生很多lib文件 -
完毕
VS的配置
分别点击
调试->调试属性->VC++目录
你可以在右框中找到包含目录和库目录两项,分别添加to_your_boost_path/
和to_your_boost_path/stage/lib
这两个目录即可。
vs2019无法打开文件“libboost_*-vc14*-mt-gd-*.lib”
boost使用需要先编译,然后来调用这个lib库。所以才会出现下面的这种报错。
错误 LNK1104 无法打开文件“libboost_thread-vc141-mt-gd-x64-1_69.lib”
下面是结局的步骤。先说一下报错的原因,这个文件名是libboost_thread-vc141-mt-gd-1_69.lib,
第一个表示的是vc141表示使用的是vc141进行编辑的,也就是vc2017,如果是vs2015就应该出来vc140;
第二个mt表示的是使用threading=muti多线程编译出来的。
第三个gd表示的是debug版本,与其对应的是release版本。
第四个x64表示的是64位系统,如果是x86表示的就是32位系统,还有1_69表示的就是boost版本是1_69_0.,如果是1_70表示的就是boost1_70_0。所以这个地方注意两点,1就是你下载的boost版本要对应,2就是使用vs编译的版本要对应。
1.首先需要下载boost,我这里下载的是boost1.69 boost官网,
2.解压boost,解压之后的图为
3.使用开发人员命令提示,右键使用管理员身份打开,
打开之后可以看到如下图,然后定位到boost_1.69_0的目录下
然后运行里面的bootstrap.bat文件。
然后使用下列语句进行编译
bjam stage --toolset=msvc-14.1 --without-python --stagedir="c:\Boost" link=static runtime-link=shared runtime-link=static threading=multi debug release
然后就是等待漫长的编译过程,在这个过程中,我们可以先看一下编译出来的东西是不是跟我们预期的一样的。
可以看到写的路径c:\boost里面已经有了一个lib文件夹,这里面就是我们所需要的lib
等了不到两分钟,就可以看到里面已经有了我想要的,因此大功告成。
喜欢的或者有问题的可以点个赞,或者下面评论。
关于这条语句的说明,突然给这条语句我很懵,而且都不知道是干啥的,而且最开始看到的博客只给出了一条语句,但是没有说到底是为啥用这个语句,下面是这条语句的详细说明
1)stage/install:
stage表示只生成库(dll和lib),install还会生成包含头文件的include目录。本人推荐使用stage,因为install生成的这个include目录实际就是boost安装包解压缩后的boost目录(D:\boost\boost_1_70_0,只比include目录多几个非hpp文件,都很小),所以可以直接使用,而且不同的IDE都可以使用同一套头文件,这样既节省编译时间,也节省硬盘空间。
(2)toolset:
指定编译器,可选的如borland、gcc、msvc(VC6)、msvc-9.0(VS2008)等,VS2019对应msvc-版本我查不到,就是用了14。
下面是vs对应的msvc的版本
-
MSVC++ 14.0 _MSC_VER == 1900 (Visual Studio 2015)
-
MSVC++ 12.0 _MSC_VER == 1800 (Visual Studio 2013)
-
MSVC++ 11.0 _MSC_VER == 1700 (Visual Studio 2012)
-
MSVC++ 10.0 _MSC_VER == 1600 (Visual Studio 2010)
-
MSVC++ 9.0 _MSC_VER == 1500 (Visual Studio 2008)
-
MSVC++ 8.0 _MSC_VER == 1400 (Visual Studio 2005)
-
MSVC++ 7.1 _MSC_VER == 1310 (Visual Studio 2003)
-
MSVC++ 7.0 _MSC_VER == 1300
-
MSVC++ 6.0 _MSC_VER == 1200
-
MSVC++ 5.0 _MSC_VER == 1100
(3)without/with:
选择不编译/编译哪些库。因为python、mpi等库我都用不着,所以排除之。还有wave、graph、math、regex、test、program_options、serialization、signals这几个库编出的静态lib都非常大,所以不需要的也可以without掉。这可以根据各人需要进行选择,默认是全部编译。但是需要注意,如果选择编译python的话,是需要python语言支持的,应该到python官方主页http://www.python.org/下载安装。
查看boost包含库的命令是bjam --show-libraries。
(4)stagedir/prefix:
stage时使用stagedir,install时使用prefix,表示编译生成文件的路径。我这里直接保存到了“D\boost“目录下了。
(5)build-dir:
编译生成的中间文件的路径。这个本人这里没用到,默认就在根目录(E:\SDK\boost)下,目录名为bin.v2,等编译完成后可将这个目录全部删除(没用了),所以不需要去设置。
(6)link:
生成动态链接库/静态链接库。生成动态链接库需使用shared方式,生成静态链接库需使用static方式。一般boost库可能都是以static方式编译,因为最终发布程序带着boost的dll感觉会比较累赘。
(7)runtime-link:
动态/静态链接C/C++运行时库。同样有shared和static两种方式,这样runtime-link和link一共可以产生4种组合方式,各人可以根据自己的需要选择编译。
(8)threading:
单/多线程编译。一般都写多线程程序,当然要指定multi方式了;如果需要编写单线程程序,那么还需要编译单线程库,可以使用single方式。
(9)debug/release:
编译debug/release版本。一般都是程序的debug版本对应库的debug版本,所以两个都编译。
编译完成之后就可以看到,在d盘的boost下就会有两个文件夹:
然后lib下面就是我们所需要的libboost_threadXXX的文件。
vs2019+win10配置boost库的详细教程
boost介绍
boost是一个准标准库,相当于STL的延续和扩充,它的设计理念和STL比较接近,都是利用泛型让复用达到最大化。不过对比STL,boost更加实用。 STL集中在算法部分,而boost包含了不少工具类,可以完成比较具体的工作。
Boost库是为C++语言标准库提供扩展的一些C++程序库的总称。Boost库由Boost社区组织开发、维护。其目的是为C++程序员提供免费、同行审查的、可移植的程序库。Boost库可以与C++标准库完美共同工作,并且为其提供扩展功能。Boost库使用Boost License来授权使用,根据该协议,商业的非商业的使用都是允许并鼓励的。
Boost社区建立的初衷之一就是为C++的标准化工作提供可供参考的实现,Boost社区的发起人Dawes本人就是C++标准委员会的成员之一。在Boost库的开发中,Boost社区也在这个方向上取得了丰硕的成果。在送审的C++标准库TR1中,有十个Boost库成为标准库的候选方案。在更新的TR2中,有更多的Boost库被加入到其中。从某种意义上来讲,Boost库成为具有实践意义的准标准库。
大部分boost库功能的使用只需包括相应头文件即可,少数(如正则表达式库,文件系统库等)需要链接库。里面有许多具有工业强度的库,如graph库。
很多Boost中的库功能堪称对语言功能的扩展,其构造用尽精巧的手法,不要贸然的花费时间研读。Boost另外一面,比如Graph这样的库则是具有工业强度,结构良好,非常值得研读的精品代码,并且也可以放心的在产品代码中多多利用。
boost主要包含一下几个大类:字符串及文本处理、容器、迭代子(Iterator)、算法、函数对象和高阶编程、泛型编程、模板元编程、预处理元编程、并发编程、数学相关、纠错和测试、数据结构、输入/输出、跨语言支持、内存相关、语法分析、杂项。 有一些库是跨类别包含的,就是既属于这个类别又属于那个类别。
boost库:
Boost库是为C++语言标准库提供扩展的一些C++程序库的总称,由Boost社区组织开发、维护。Boost库可以与C++标准库完美共同工作,并且为其提供扩展功能。
一.下载boost库
直接去官网下载http://www.boost.org
中间位置有download点击。选择要下载的安装包。这里我用的是windows,选择的是boost_1_73_0.zip。linux可以选择后缀为tar.gz和其他的。
二.编译
下载好后,解压,得到文件目录如下图,找到其中的bootstrap.bat文件:
然后打开vs2019的命令行:这里选择64位或者32位的都可以。我选择的是x86_x64的。
然后切换到你解压到的路径。运行bootstrap.bat。
1
2
|
cd D:\aboost\boost_1_73_0 bootstrap.bat //运行 |
运行之后,查看boost_1_73_0下会多出几个文件。b2。运行b2.
这里运行的时间有点长,等待就行,最后运行成功之后会显示。
在使用boost库包含上面的文件夹与链接库。
三.测试boost
1.打开VS2019,新建一个空C++项目,并创建main.cpp 文件。点击项目的属性。
2.在vc++目录中包含目录添加boost路径D:\aboost\boost_1_73_0,库目录添加D:\aboost\boost_1_73_0\stage\lib。保存即可。
3.测试(以多线程并行排序为例)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#include <iostream> #include <boost/sort/sort.hpp> #include <algorithm> #include <vector> using namespace std; int main() { vector< int > arr; while (arr.size() < 100) arr.push_back(std:: rand ()); boost::sort::block_indirect_sort(std::begin(arr), std::end(arr)); for_each(std::begin(arr), std::end(arr), []( int & a) { cout << a << "\t" ; }); return 0; } |
这里运行注意要选择,你之前命令行选择的版本,要不然boost不会包含在内,会出错。
VS2019配置BOOST的方法(v1.70.0库)
安装编译Boost c++ library
安装Boost库
官网下载:https://www.boost.org/users/history/version_1_70_0.html
最新版本1.70.0. (低于1.7.0的版本可能在vs2019中支持不完善,编译或运行时发生不可预料的bug)
下载好后,解压,得到文件目录如下图,找到其中的bootstrap.bat文件:
双击运行可能出现闪退,最好的办法(亲测有效): 选择vs2019 —> visual studio tools —> vc —> x86_x64 Cross Tools Command Prompt for VS 2,打开命令行:
切换到boost_1_70_0的安装目录,(本人安装路径:E:\program\boost_1_70_0)
1
2
|
cd E:\program\boost_1_70_0 bootstrap.bat # 执行 |
执行会发现当前文件夹中增加了几个文件,找到其中的bjam.exe,如下图所示
命令行执行:
bjam.exe --toolset=msvc-14.1 architecture=x86 address-model=64 link=static --build-type=complete --with-system --with-thread --with-date_time --with-filesystem --with-serialization
Note:
MSVC 版本号对应
1.MSVC++ 14.0 _MSC_VER == 1900 (Visual Studio 2015)
2.MSVC++ 12.0 _MSC_VER == 1800 (Visual Studio 2013)
3.MSVC++ 11.0 _MSC_VER == 1700 (Visual Studio 2012)
4.MSVC++ 10.0 _MSC_VER == 1600 (Visual Studio 2010)
5.MSVC++ 9.0 _MSC_VER == 1500 (Visual Studio 2008)
6.MSVC++ 8.0 _MSC_VER == 1400 (Visual Studio 2005)
7.MSVC++ 7.1 _MSC_VER == 1310 (Visual Studio 2003)
8.MSVC++ 7.0 _MSC_VER == 1300
9.MSVC++ 6.0 _MSC_VER == 1200
10.MSVC++ 5.0 _MSC_VER == 1100
vs2019 可以支持boost c++ library 针对msvc-14.1的编译选项
等待5-10min即可完成。
最后两个路径会在使用Boost库时工程属性中包含目录和库目录中用到。
The Boost C++ Libraries were successfully built.
the following directory should be added to compiler include paths:
E:\program\boost_1_70_0
the following directory should be added to linker library paths:
E:\program\boost_1_70_0\stage\lib
这时boost库已经安装、编译成功。
新建vs2019 c++项目,并添加boost依赖库
点击菜单栏 项目——>属性——>选择VC++目录,在包含目录 和 库目录添加以上2个路径,如下图:
或可以新建一个系统环境变量BOOST_DIR,值为E:\program\boost_1_70_0。
在path系统环境变量中添加:%BOOST_DIR%;
VC++包含目录中添加: %BOOST_DIR%;
VC++库目录中添加: %BOOST_DIR%\stage\lib;
代码测试
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
#include <boost/lexical_cast.hpp> #include <iostream> using namespace std; using namespace boost; int main() { //system("chcp 65001"); double a = lexical_cast< double >( "3.1415926" ); string str = lexical_cast<string>( "3.1415926" ); cout << "This is a number: " << a << endl; cout << "This is a string: " << str << endl; int b = 0; try { b = lexical_cast< int >( "neo" ); } catch (bad_lexical_cast& e) { cout << e.what() << endl; } return 0; } |
运行输出(正常):
This is a number: 3.14159
This is a string: 3.1415926
bad lexical cast: source type value could not be interpreted as target
c++ boost库说明
官网最新版文档说明:https://www.boost.org/doc/libs/1_70_0/
Boost库是一个可移植、提供源代码的C++库,作为标准库的后备,是C++标准化进程的开发引擎之一,是为C++语言标准库提供扩展的一些C++程序库的总称。 Boost库由C++标准委员会库工作组成员发起,其中有些内容有望成为下一代C++标准库内容。在C++社区中影响甚大,是不折不扣的“准”标准库。Boost由于其对跨平台的强调,对标准C++的强调,与编写平台无关。大部分boost库功能的使用只需包括相应头文件即可,少数(如正则表达式库,文件系统库等)需要链接库。但Boost中也有很多是实验性质的东西,在实际的开发中使用需要谨慎。
Boost库由Boost社区组织开发、维护。其目的是为C++程序员提供免费、同行审查的、可移植的程序库。Boost库可以与C++标准库完美共同工作,并且为其提供扩展功能。Boost库使用Boost License来授权使用。
Boost社区建立的初衷之一就是为C++的标准化工作提供可供参考的实现,Boost社区的发起人Dawes本人就是C++标准委员会的成员之一。在Boost库的开发中,Boost社区也在这个方向上取得了丰硕的成果。在送审的C++标准库TR1中,有十个Boost库成为标准库的候选方案。在更新的TR2中,有更多的Boost库被加入到其中。从某种意义上来讲,Boost库成为具有实践意义的准标准库。
可下载Boost C++ Libraries安装boost库。大部分boost库功能的使用只需包括相应头文件即可,少数(如正则表达式库,文件系统库等)需要链接库。里面有许多具有工业强度的库,如graph库。
主要分类
按照功能分类的Boost库列表
按照实现的功能,Boost 可为大致归入以下20个分类,在下面的分类中,有些库同时归入几种类别。
字符串和文本处理
a) Conversion
b) Format
c) IOStream
d) Lexical Cast
e) Regex
f) Spirit
g) String Algo
h) Tokenizer
i) Wave
j) Xpressive
容器
a) Array
b) Bimap
c) Circular Buffer
d) Disjoint Sets
e) Dynamic Bitset
f) GIL
g) Graph
h) ICL
i) Intrusive
j) Multi-Array
k) Multi-Index
l) Pointer Container
m) Property Map
n) Property Tree
o) Unordered
p) Variant
迭代器
a) GIL
b) Graph
c) Iterators
d) Operators
e) Tokenizer
算法
a) Foreach
b) GIL
c) Graph
d) Min-Max
e) Range
f) String Algo
g) Utility
函数对象和高阶编程
a) Bind
b) Function
c) Functional
d) Functional/Factory
e) Functional/Forward
f) Functional/Hash
g) Lambda
h) Member Function
i) Ref
j) Result Of
k) Signals
l) Signals2
m) Utility
泛型编程
a) Call Traits
b) Concept Check
c) Enable If
d) Function Types
e) GIL
f) In Place Factory, Typed In Place Factory
g) Operators
h) Property Map
i) Static Assert
j) Type Traits
模板元编程
a) Function Types
b) Fusion
c) MPL
d) Proto
e) Static Assert
f) Type Traits
预处理元编程
a) Preprocessors
并发编程
a) Asio
b) Interprocess
c) MPI
d) Thread
数学和数字
a) Accumulators
b) Integer
c) Interval
d) Math
e) Math Common Factor
f) Math Octonion
g) Math Quaternion
h) Math/Special Functions
i) Math/Statistical Distributions
j) Multi-Array
k) Numeric Conversion
l) Operators
m) Random
n) Rational
o) uBLAS
排错和测试
a) Concept Check
b) Static Assert
c) Test
数据结构
a) Any
b) Bitmap
c) Compressed Pair
d) Fusion
e) ICL
f) Multi-Index
g) Pointer Container
h) Property Tree
i) Tuple
j) Uuid
k) Variant
图像处理
a) GIL
输入输出
a) Asio
b) Assign
c) Format
d) IO State Savers
e) IOStreams
f) Program Options
g) Serialization
跨语言混合编程
a) Python
内存管理
a) Pool
b) Smart Ptr
c) Utility
解析
a) Spirit
编程接口
a) Function
b) Parameter
杂项
a) Compressed Pair
b) Conversion
c) CRC
d) Date Time
e) Exception
f) Filesystem
g) Flyweight
h) Lexical Cast
i) Meta State Machine
j) Numeric Conversion
k) Optional
l) Polygon
m) Program Options
n) Scope Exit
o) Statechart
p) Swap
q) System
r) Timer
s) Tribool
t) Typeof
u) Units
v) Utility
w) Value Initialized
编译器问题的变通方案
a) Compatibility
b) Config
常用库
- Regex
- 正则表达式库
- Spirit
- LL parser framework,用C++代码直接表达EBNF
- Graph
- 图组件和算法
- Lambda
- 在调用的地方定义短小匿名的函数对象,很实用的functional功能
- concept check
- 检查泛型编程中的concept
- Mpl
- 用模板实现的元编程框架
- Thread
- 可移植的C++多线程库
- Python
- 把C++类和函数映射到Python之中
- Pool
- 内存池管理
- smart_ptr
- 5个智能指针,学习智能指针必读,一份不错的参考是来自CUJ的文章:
相关图书编辑
- Boost程序库完全开发指南:深入C++“准”标准库
- C++11/14高级编程:Boost程序库探秘(第3版)
- Boost程序库探秘:深度解析C++准标准库
boost的编译和使用,经过搜集资料和总结,记录成文。感谢文后所列参考资料的作者。
1 下载
地址:http://sourceforge.net/projects/boost/files/boost/1.56.0/
可以选择 boost_1_56_0.7z 下载。
2 编译
2.1 生成boost的自用的编译工具bjam.exe
解压后,使用VS2013编译。首先打开“VS2013 开发人员命令提示”,cd 到boost解压后的根目录:E:\XXX\boost_1_56_0,执行bootstrap.bat。会在boost根目录生成 b2.exe 、bjam.exe 、project-config.jam 、bootstrap.log四个文件。
其中,b2.exe 、bjam.exe 这两个exe作用是一样的,bjam.exe 是老版本,b2是bjam的升级版本。
2.2 使用bjam(或b2)来编译boost
1. bjam命令参数分析
我们以文章【1】中的命令来分析一下各个参数的作用(原作者解压后的boost根目录为E:\SDK\boost)。
bjam stage --toolset=msvc-9.0 --without-python --stagedir="E:\SDK\boost\bin\vc9" link=static runtime-link=shared runtime-link=static threading=multi debug release
(1)stage/install:
stage表示只生成库(dll和lib),install还会生成包含头文件的include目录。本人推荐使用stage,因为install生成的这个include目录实际就是boost安装包解压缩后的boost目录(E:\SDK\boost\boost,只比include目录多几个非hpp文件,都很小),所以可以直接使用,而且不同的IDE都可以使用同一套头文件,这样既节省编译时间,也节省硬盘空间。
(2)toolset:
指定编译器,可选的如borland、gcc、msvc(VC6)、msvc-9.0(VS2008)等。
(3)without/with:
选择不编译/编译哪些库。因为python、mpi等库我都用不着,所以排除之。还有wave、graph、math、regex、test、program_options、serialization、signals这几个库编出的静态lib都非常大,所以不需要的也可以without掉。这可以根据各人需要进行选择,默认是全部编译。但是需要注意,如果选择编译python的话,是需要python语言支持的,应该到python官方主页http://www.python.org/下载安装。
查看boost包含库的命令是bjam --show-libraries。
(4)stagedir/prefix:
stage时使用stagedir,install时使用prefix,表示编译生成文件的路径。推荐给不同的IDE指定不同的目录,如VS2008对应的是E:\SDK\boost\bin\vc9,VC6对应的是E:\SDK\boost\bin\vc6,否则都生成到一个目录下面,难以管理。如果使用了install参数,那么还将生成头文件目录,vc9对应的就是E:\SDK\boost\bin\vc9\include\boost-1_46\boost,vc6类似(光这路径都这样累赘,还是使用stage好)。
(5)build-dir:
编译生成的中间文件的路径。这个本人这里没用到,默认就在根目录(E:\SDK\boost)下,目录名为bin.v2,等编译完成后可将这个目录全部删除(没用了),所以不需要去设置。
(6)link:
生成动态链接库/静态链接库。生成动态链接库需使用shared方式,生成静态链接库需使用static方式。一般boost库可能都是以static方式编译,因为最终发布程序带着boost的dll感觉会比较累赘。
(7)runtime-link:
动态/静态链接C/C++运行时库。同样有shared和static两种方式,这样runtime-link和link一共可以产生4种组合方式,各人可以根据自己的需要选择编译。
(8)threading:
单/多线程编译。一般都写多线程程序,当然要指定multi方式了;如果需要编写单线程程序,那么还需要编译单线程库,可以使用single方式。
(9)debug/release:
编译debug/release版本。一般都是程序的debug版本对应库的debug版本,所以两个都编译。
2. 编译boost
编译boost的命令比较复杂,尤其是 link, runtime-link 这两个选项的功能分不太清楚,他们共有4种相互组合,这些相互组合各有什么含义呢?
所以首先做个实验,仅编译date_time库,观察一下这两个选项的作用。
分别使用下面的命令行编译,
b2 stage --toolset=msvc-12.0 --with-date_time --stagedir="E:\eCode\boost_1_56_0\bin\vc12" link=static runtime-link=static threading=multi debug release b2 stage --toolset=msvc-12.0 --with-date_time --stagedir="E:\eCode\boost_1_56_0\bin\vc12" link=static runtime-link=shared threading=multi debug release b2 stage --toolset=msvc-12.0 --with-date_time --stagedir="E:\eCode\boost_1_56_0\bin\vc12" link=shared runtime-link=shared threading=multi debug release b2 stage --toolset=msvc-12.0 --with-date_time --stagedir="E:\eCode\boost_1_56_0\bin\vc12" link=shared runtime-link=static threading=multi debug release b2 stage --toolset=msvc-12.0 --with-date_time --stagedir="E:\eCode\boost_1_56_0\bin\vc12_2" (为避免将前面的结果覆盖,配置另一目录vc12_2存放)
b2 stage --toolset=msvc-12.0 --with-date_time --stagedir="E:\eCode\boost_1_56_0\bin\vc12_2" --build-type=complete(为避免将前面的结果覆盖,配置另一目录vc12_3存放)
所得到的结果如下表所示:
序号 | link | runtime-link | 生成物 | 备注 |
1 | static | static |
libboost_date_time-vc120-mt-sgd-1_56.lib libboost_date_time-vc120-mt-s-1_56.lib |
|
2 | static | shared |
libboost_date_time-vc120-mt-gd-1_56.lib libboost_date_time-vc120-mt-1_56.lib |
与5结果相同 |
3 | shared | shared |
boost_date_time-vc120-mt-gd-1_56.dll boost_date_time-vc120-mt-gd-1_56.lib boost_date_time-vc120-mt-1_56.dll boost_date_time-vc120-mt-1_56.lib |
|
4 | shared | static | 报错,无法编译 | |
5 | 使用缺省 | 使用缺省 |
libboost_date_time-vc120-mt-gd-1_56.lib libboost_date_time-vc120-mt-1_56.lib |
与2结果相同 并且在省略debug release时,debug release版本都编译 |
6 | 使用--build-type=complete |
boost_date_time-vc120-mt-gd-1_56.dll boost_date_time-vc120-mt-gd-1_56.lib boost_date_time-vc120-mt-1_56.dll boost_date_time-vc120-mt-1_56.lib
libboost_date_time-vc120-mt-sgd-1_56.lib libboost_date_time-vc120-mt-s-1_56.lib
libboost_date_time-vc120-mt-gd-1_56.lib libboost_date_time-vc120-mt-1_56.lib
libboost_date_time-vc120-s-1_56.lib libboost_date_time-vc120-sgd-1_56.lib |
--build-type=complete时,可以看到link,runtime-link的 3种组合下debug, release的多线程版本都生成出来了, 除此之外,还生成了link=static,runtime-link=static的debug, release的单线程版本 |
从上面的结果可以看到,link和runtime-link的缺省配置是 link=static runtime-link=shared,所以我们可以使用 (b2 stage --toolset=msvc-12.0 --with-date_time --stagedir="E:\eCode\boost_1_56_0\bin\vc12_2")命令行来编译boost。
另外,我们还可以分析一下 boost 库的命名特点:【2】
(1)以“lib”开头的是“link=static”版本(静态链接库版本,没有dll),而直接以“boost”开头的是“link=shared”版本(动态链接库版本,包含lib和dll)。
(2)所有的库都含有"boost"前缀。
(3)紧随其后的是boost库名称(比如date_time库)。
(4)然后是编译器的版本,与库名称之间以"-"而不是下划线"_"分隔(比如 -vc120)。
(5)有“mt”的为“threading=multi”版本,没有的则是“threading=single”版本。
(6)有“s”的为“runtime-link=static”版本,没有的则是“runtime-link=shared”版本。
(7)有“gd”的为debug版本,没有的则是release版本。
(8)所有的库都含有boost库的版本号结尾(比如1_56,其中的"."以下划线"_"代替)
3. link, runtime-link 组合分析
文章【2】给出了link,runtime-link的具体作用分析。
假设一个库A依赖于库B,我们自己的程序client依赖于库A,即:
那么,link指的是client->A,runtime-link指的是A -> B
配置 |
链接过程 |
运行时需要的文件 |
link=static runtime-link=static |
client通过A.a (A.lib)静态包含A; A通过B.a (B.lib)静态包含B; 不关 .so .dll的事 |
client |
link=static runtime-link=shared |
client通过A.a (A.lib)静态包含A; 在运行时,client要动态调用B.so (B.dll) |
client B.so (B.dll) |
link=shared runtime-link=shared |
client会包含A.a (A.lib); A会包含 B.a (B.lib); 但都只保存动态库的真正实现的stub,运行时通过stub去动态加载 A.so (A.dll), B.so (B.dll) 中的实现 |
client A.so (A.dll) B.so (B.dll) |
link=shared runtime-link=static |
client会包含A.a (A.lib),但只包含真正实现的stub; A通过B.a (B.lib)静态包含B; 运行时,client会动态调用A.so (A.dll) |
client A.so (A.dll)
|
3. 配置
包含头文件的Include路径:E:\eCode\boost_1_56_0
包含库文件的链接路径:E:\eCode\boost_1_56_0\bin\vc12\lib
(1)可以设置为仅用于当前project:
选中当前project->Properties->Configuration Properties->C/C++->General: Additional Include Directories: 设置 E:\eCode\boost_1_56_0
选中当前project->Properties->Configuration Properties->Linker->General: Additional LibraryDirectories: 设置 E:\eCode\boost_1_56_0\bin\vc12\lib
(2)可设置为仅用于当前Solution:
选中当前project->Properties->Configuration Properties->VC++ Directories:
Include Directories: 设置 E:\eCode\boost_1_56_0
LibraryDirectories: 设置 E:\eCode\boost_1_56_0\bin\vc12\lib
(3)可设置为OS当前用户下的VC++环境(当前用户下VC++所创建的所有Solution)
在某个已打开的工程下,切换到Property Manager 选项卡,然后然后展开当前工程的properties配置,打开Microsoft.Cpp.Win32.User
选择Common Properties->VC++ Directories:
Include Directories: 设置 E:\eCode\boost_1_56_0
LibraryDirectories: 设置 E:\eCode\boost_1_56_0\bin\vc12\lib
这样设置的仅在Win32编译选项下起作用,x64编译选项需要另外配置x64的properties sheet。
(4)可设置为OS所有用户下的VC++环境
可以编辑 Microsoft.Cpp.Default.props 、Microsoft.Cpp.props 。这里就不介绍了。
4. 测试
使用文章【3】中date_time计时函数。创建一个Win32 console 工程,然后copy下面代码
//#define BOOST_DATE_TIME_SOURCE #include <iostream> #include <boost/date_time/gregorian/gregorian.hpp> #include <boost/date_time/posix_time/posix_time.hpp> using namespace std; using namespace boost::gregorian; using namespace boost::posix_time; /************************************************************************ 创建微秒级的计时器 ************************************************************************/ template <class T = microsec_clock> class MyTimer { private: ptime m_startTime; public: MyTimer() { Restart(); } void Restart() { m_startTime = T::local_time(); } void Elapsed() { cout << T::local_time() - m_startTime << endl; } }; int main() { MyTimer<microsec_clock> t; for(int i = 0; i < 100; ++i) { cout << "hello" << endl; } t.Elapsed(); }
注意开头的宏 “#define BOOST_DATE_TIME_SOURCE” 注掉了。若启用这个宏定义,则默认由编译器重新编译嵌入的头文件;若不启用这个宏定义,则表示使用系统已编译好的date_time库。
(1)禁用#define BOOST_DATE_TIME_SOURCE 宏,然后将 libboost_date_time-vc120-mt-gd-1_56.lib 从 E:\eCode\boost_1_56_0\bin\vc12\lib 中移除,编译debug版的程序时,提示连接错误,缺少libboost_date_time-vc120-mt-gd-1_56.lib。
(2)启用#define BOOST_DATE_TIME_SOURCE 宏,编译debug版的程序时,可发现即使在缺少 libboost_date_time-vc120-mt-gd-1_56.lib的情况下,也能成功编译。
References
【1】Boost下载安装编译配置使用指南(含Windows、Linux以及ARM Linux)(http://www.cnblogs.com/wondering/archive/2009/05/21/boost_setup.html)
【2】link 和 runtime-link,搭配shared 和 static(http://blog.csdn.net/yasi_xi/article/details/8660549)
【3】计时函数(二)(http://www.cnblogs.com/jerry19880126/archive/2013/02/20/2919718.html)
【4】官方文档Getting Started on Windows(http://www.boost.org/doc/libs/1_56_0/more/getting_started/windows.html)
【5】bjam使用(http://blog.chinaunix.net/uid-22301538-id-3158997.html)