Boost安装需区分头文件库与需编译组件:头文件库(如asio、optional)直接包含即可用;regex、filesystem等需编译生成二进制库。推荐vcpkg(Windows)或系统包管理器(Linux/macOS)安装,手动编译仅限特殊需求。

Boost 不是像普通第三方库那样“一键安装”就完事的,它本质是一套头文件为主、部分需编译的 C++ 通用库集合。安装方式取决于你用的平台和构建工具,核心原则是:头文件库直接包含就能用;带源码的组件(如 regex、filesystem、thread)需要先编译生成 .lib/.a 或 .dll/.so。
Windows + Visual Studio:推荐用 vcpkg 管理
vcpkg 是微软维护的跨平台 C++ 包管理器,对 Boost 支持非常成熟,省去手动编译烦恼。
- 安装 vcpkg(需 Git 和 VS 工具链):git clone https://github.com/Microsoft/vcpkg && cd vcpkg && .\bootstrap-vcpkg.bat
- 集成到 VS(只需一次):.\vcpkg integrate install
- 安装 Boost 模块(例如 filesystem 和 system):.\vcpkg install boost-filesystem boost-system
- VS 新建项目后,无需额外配置头文件或链接库——vcpkg 会自动注入包含路径和链接项
Linux/macOS:用包管理器最省心
主流发行版都已打包 Boost,版本较新且与系统工具链兼容性好。
- Ubuntu/Debian:sudo apt install libboost-all-dev(含全部头文件 + 预编译库)
- macOS(Homebrew):brew install boost
- 编译时链接示例(以 filesystem 为例):g++ main.cpp -lboost_filesystem -lboost_system
- 注意:部分 Boost 库(如 program_options、serialization)必须链接,不能只靠头文件
头文件-only 库:拿来即用,不用编译
Boost 中约 2/3 的库是纯模板实现,只需 #include 对应头文件,不依赖编译步骤。
立即学习“C++免费学习笔记(深入)”;
- 典型代表:asio(网络)、optional、variant、container、algorithm、range
- 使用方式极简:#include
或 #include - 只要你的编译器支持 C++11 及以上(推荐 C++17),这些库基本开箱即用
- 小提醒:Boost.Asio 默认使用系统原生 API,若需 SSL 支持,仍要链接 OpenSSL 库
自己编译 Boost(仅当必须时)
比如你要用特定编译器(Clang on Windows)、启用了特殊选项(静态链接、地址 sanitizer),或目标环境无包管理器。
- 下载源码后进入目录,运行 bootstrap.bat(Windows)或 ./bootstrap.sh(Linux/macOS)
- 生成 bjam 构建工具,再执行:b2 install --prefix=/your/install/path
- 常用选项举例:b2 link=static runtime-link=shared cxxstd=17 -j4
- 编译后,设置 BOOST_ROOT 环境变量,并在 CMake 中添加:find_package(Boost 1.70 REQUIRED COMPONENTS filesystem system)
基本上就这些。Boost 入门不复杂但容易忽略“哪些要链接、哪些不用”,记住一个口诀:头文件里没 .cpp 的,大概率不用编译;名字带 “boost_” 开头的 .lib/.a 文件,就是得链接的那部分。从 boost::optional 或 boost::filesystem 写个小程序开始试,比看文档更快上手。










