头文件就是库
使用者最常问的问题就是“我该怎么安装Boost”,这个也是我一开始最关心的问题,Boost这点做的很好,将大部分实现都封装在头文件里,所以对于一些基本的Boost库,其实是不需要安装的,只需要将头文件include到自己的程序里,当然前提是你把Boost的所有用到的头文件都拷贝了一份。
Boost是如何做到这点的?
这是因为Boost的头文件(*.hpp)包含了模板和内联函数,这点随便找一个hpp文件来看你就明白了,所以不需要去静态链接或者动态链接二进制lib库了。
不过Boost的某些库还是需要生成二进制的库的,如果你要使用他们,必须编译安装哦,他们是:
Boost.Filesystem
Boost.IOStreams
Boost.ProgramOptions
Boost.Python
Boost.Regex
Boost.Serialization
Boost.Signals
Boost.Thread
Boost.Wave
技巧1
可以通过在VS预处理器中添加BOOST_LIB_DIAGNOSTIC,在编译的output窗口中输出程序具体链接了哪些boost库以及链接顺序
技巧2
可以通过修改源码boost/config/user.hpp中,取消// #define BOOST_ALL_NO_LIB的注释,重新编译Boost源码,关闭Boost自动链接
在如下一种情况下需要关闭自动连接功能:因为asio自动连接了system,data_time和regex库,其实平常只用到了system库,而data_time和regex,如果不使用deadline_timer和asyn_read_until之类的东西的话,是不用连接的.
命名规则
libboost_filesystem-vc80-mt-sgdp-1_42.lib
前缀:统一为lib,但在Windows下只有静态库有lib前缀;
库名称:以"boost一”开头的库名称,在这里是boost_filesystem;
编译器标识:编译该库文件的编译器名称和版本,在这里是-vc80;
多线程标识:支持多线程使用-mt,没有表示不支持多线程;
ABI标识:这个标识比较复杂,标识了Boost库的几个编译链接选项;
s: 静态库标识;
gd:debug版标识;
p: 使用STlport而不是编译器自带STL实现;
版本号:Boost库的版本号,小数点用下画线代替,在这里是1_42;
扩展名:在Windows上是lib,在Linux等类Unix操作系统上是a或者.so。
boost 链接出错无法打开libboost_thread-vc140-mt-sgd
第一个链接说明,当选择什么样子的运行时库,程序在编译的时候,就会去调用相应编译时期指定的版本,比如s代表的是运行时静态库,gd代表的是调试模式,当出现无法打开上面的情况下,说明放在指定目录下的boost编译库可能是动态库,跟目标的不一致,因此需要调整匹配上
“多线程(/MT)”: release版本多线程静态库
需要使用 libboost_regex-vc90-mt-s-1_44.lib
“多线程调试(/MTd)”:debug版本多线程静态程库
需要使用 libboost_regex-vc90-mt-sgd-1_44.lib
“多线程 DLL(/MD)”: release版本多线程动态库
需要使用
静态boost 库连接
libboost_regex-vc90-mt -1_44.lib
动态boost 库连接, 需要在引入库前加上“lib”,
运行需要带上对应的dll
boost_regex-vc90-mt-1_44.lib à在引入库前加上“lib”
boost_regex-vc90-mt-1_44.dll
“多线程调试 DLL(/MDd)”: debug版本多线程动态库
需要使用
静态boost 库连接
libboost_regex-vc90-mt-gd-1_44.lib
动态boost 库连接, 需要在引入库前加上“lib”,
运行需要带上对应的dll
boost_regex-vc90-mt-gd-1_44.lib à在引入库前加上“lib”
boost_regex-vc90-mt-gd-1_44.dll
http://www.cnblogs.com/bluedoctor/p/6236905.html
http://blog.csdn.net/xucuiping_/article/details/5979532