官方下载 http://www.boost.org/users/news/
说明:似乎只能下载比较新的几个版本,如果你用旧版,貌似我没发现有下载的地方,注意下载Unix版本
Boost库各个版本下载地址:
https://sourceforge.net/projects/boost/files/boost-binaries/
说明:依然开源网站可以下载到各种版本,尤其是你使用的旧版本,
Windows免安装的会场方便
ubuntu 16.04,5年稳定版,boost 1.65,比较新,
说明:Ubuntu的GCC版本为5.4,2016的稳定版,已经支持C++11,
boost1.65是2017年的版本,所以应当可以和C++11匹配,预计过老的GCC可能因为无法支持C++11导致编译boost失败,
相信你已经看过无数的安装文章,这里按照我的经验来说明:
boost_1_65_0.tar.gz
1 解压
tar -zxvf boost_1_65_0.tar.gz
cd boost_1_65_0
2 bootstrap.sh
讲真,这个东西可以加参数,但并不清楚这个到底干嘛用,有人说是配好环境,也有复杂的说法,
一个说法:1. 运行bootstrap.sh:后面加上需要编译的库(如果不加的话,貌似只会编译最小的库,即包含基本功能的库)需要编译的自己选(可以见参考网址2里面完全编译)。
一个说法:生成bjam,上述命令可以带有各种选项,具体可参考帮助文档: ./bootstrap.sh –help。其中–prefix参数,可以指定安装路径,如果不带–prefix参数的话(推荐),默认路径是 /usr/local/include 和 /usr/local/lib,分别存放头文件和各种库。执行完成后,会生成bjam,已经存在的脚本将会被自动备份。注意,boost 1.49会在当前目录下,生成两个文件bjam和b2,这两个是一样的,
编译完成后,进行安装,也就是将头文件和生成的库,放到指定的路径(–prefix)下,
的确可以加这种参数,但我没试过,不懂shell,看不太懂,不知道这个东西不加参数是否会造成生成的库变少,bootstrap.sh–help查看参数
实际使用:./bootstrap.sh或者./bootsrap.sh –with-libraries=all,个人觉得不加参数就是默认全部生成,因为我两个都执行了一下,第二个执行后没有做什么事情,
**3 安装
./b2 install –prefix=/home/hello/Myboost –build-type=complete –layout=versioned link=static threading=multi runtime-link=shared
参数解释:prefix自己指定目录,complete表示全部编译,layout貌似是指定编译生成的版本号,静态链接,多线程,运行动态,默认是生成32位库,如何生成64位,还不知道怎么改,或许是改某个参数
参数解释:
https://www.cnblogs.com/yaoyu126/p/6095392.html ,来自这位老兄
有点乱,没有好好整理格式:
本想整理一番,但是实在不知道怎么弄的像这位老兄一样整齐
编译,1个核心,4G内存,老电脑,虚拟机,编译了半个小时
项目帮助:
项目在Jamroot有Jamfile文件
用法:
B2 [options] [properties] [install|stage]
构建和安装Boost
目标及相关选项:
install 将头文件和已编译的库文件安装到 下列配置位置.
–prefix= 架构独立文件安装目录
默认; C:\Boost Win32
默认; /usr/local Unix. Linux, 等.
–exec-prefix= 架构独立文件安装目录
默认
–libdir= 库文件安装目录.
默认
–includedir=头文件安装目录.
默认; 路径/include
stage 编译和安装 已编译库文件到 stage目录.
–stagedir= 库文件安装目录
默认; ./路径
options:
–build-type= 编译指定预定义variant集的库.
注意,在编译时使用哪些variant
取决于每个库支持什么.
-- minimal -- (默认) 编译variant最小集.
在Windows上, 它们是使用共享运行库的 debug和release静态多线程库. 在Linux上,它们是 release静态和共享多线程库
-- complete -- 编译所有可用variant.
–build-dir=DIR 编译在此目录,而不是编译在 代码目录。推荐!
–show-libraries 显示需要编译的Boost库列表 和安装步骤,然后退出
–layout= 确定是否选择库名和头位置 这样能在同一个系统中
使用多版本Boost库和多编译器
-- versioned -- Boost二进制文件名称包括 Boost版本号、编译器名称和版本和编码生成属性。
Boost头文件安装在<HDRDIR>子目录<HDRDIR>的名字包含Boost版本号。
-- system -- 二进制文件名不包括 Boost版本号或编译器名称和版本 Boost头文件 安装在<HDRDIR>子目录,这个选项 用于在发布系统集成包
默认值,在Windows下为'versioned' 在Unix下为'system'
–buildid=ID 为生成库名添加指定ID 默认不添加
–python-buildid=ID 为生成依赖于Python的库名添加指定ID 默认不添加 本ID在–buildid的基础上添加
–help 显示帮助
–with- 库名 编译和安装指定library 如果使用本选项, 只会编译指定库
–without-库名 不进行编译,stage,或安装指定, 默认编译所有库
Properties
toolset=toolset :指定构建工具集
variant=debug|release 选择编译选项
link=static|shared 生成静态还是共享库
threading=single|multi 生成单线程还是多线程库
runtime-link=static|shared 静态还是动态链接C和C++运行时。
华丽的————————————–分割线
说明:默认是安装/usr/local,并且要使用root才可以,否则会造成一些错误,
但我们自己指定目录的时候,并不要root权限,完成后会生成include和lib
很多都没说明:安装之后,如果你是默认安装目录的,貌似不用建立软连接,如果是自己指定目录后,要建立软连接,
头文件:
ln -s /home/hello/Myboost/include/boost-1_65/boost (此处不要加/) /usr/include/boost
库:
写一段需要使用库的代码,比如用到regex库
gcc a.cpp -l boost_regex… -L /home/hello/Myboost/lib
注意:链接库名,不要加后缀,如.a,.so,
也不要加lib,尽管我们生成的库都是lib开头,如libboost_regex…,把lib去掉,切记,库的头lib和尾部后缀.a都要去掉,否则你会疯掉的发现根本无法编译通过,而你又不知道错在什么地方,
关于这一点,还要说明的是,头文件我们可以建立一个软连接,这个非常简单,boost库,有些部分并没有编译成库,我们只要引入头文件,编译的时候就过了,而有些需要库的,始终无法编译过,错误是未定义告别的引用这样的链接错误,这是因为编译这些东西是需要库的,网上很多文章并没有说过这一点,不知道他们怎么用,关于如何引用库,百度了很多东西,ubuntu16.04,我装好后,发现并不会去找/usr/local这个路径,所以我认为可行的方式有两种,
一个是写shell,切换到cd /etc/profile.d
目录下,使用超级用户创建文件boost.sh
里面添加如下内容
#!/bin/sh
BOOST_ROOT=/home/Lyndon/boost_1_60_0(boost的解压路径)
BOOST_INCLUDE=/usr/local/include/boost
BOOST_LIB=/usr/local/lib
export BOOST_INCLUDE BOOST_LIB BOOST_ROOT
“
这是网上看到的一个办法,因为我已经导入了include,所以我在当前的目录,/home/hello/prac/,下写了一个boost.sh,其实我不会shell
#!/bin/sh
BOOST_LIB=/home/hello/Myboost/lib
export BOOST_LIB
//然后chmod u+x boost.sh,执行以下,。./boost.sh,
这样等于执行了导入的步骤,所以直接gcc a.cpp -l boost_regex…
注意,我这个链接debug的库(末尾-d的库)成功了,但是链接release(没有-d)的是失败的,不知道为什么,但是如果自己指定路径-L编译,无论哪个版本链接都可以,或许大神可以给解释下,
2 写makefile时,加入路径
网上还有网络安装方法,我没试过,