Conan是成熟灵活的跨平台C++依赖管理工具,核心在于包定义、远程仓库、本地缓存和配置四环节;支持conanfile.txt/.py声明依赖,集成CMake生成标准文件,并可创建上传自定义包。
Conan 是 C++ 项目中成熟、灵活且跨平台的依赖管理工具,它不依赖构建系统(CMake/Make/Ninja 等均可),能统一管理头文件、静态库、动态库、构建脚本等二进制产物。用好 Conan 的关键在于理解 包定义(conanfile.py 或 conanfile.txt)、远程仓库(remote)、本地缓存(cache)和配置(profile) 四个核心环节。
在项目根目录创建 conanfile.txt(适合简单项目)或 conanfile.py(推荐用于需要自定义逻辑的项目)。
[requires] fmt/10.2.1 openssl/3.2.1[generators] CMakeDeps CMakeToolchain
[layout] cmake_layout
from conan import ConanFile from conan.tools.cmake import cmake_layoutclass MyProject(ConanFile): settings = "os", "compiler", "build_type", "arch" generators = "CMakeDeps", "CMakeToolchain"
def requirements(self): self.requires("fmt/10.2.1") if self.settings.os == "Linux": self.requires("openssl/3.2.1")
Conan 默认只启用 conancenter(官方中心仓库),但很多企业或私有包需添加自定义 remote。
conan remote list
conan remote add my-company https://my-conan.company.com/v1
conan install . --build=missing
--build=missing 表示本地没有对应二进制时自动从源码构建;生产环境建议用 --build=never 强制使用预编译包Conan 通过 CMakeDeps 和 CMakeToolchain 生成标准 CMake 文件,让 CMake 原生识别 Conan 包。
CMakeDeps 生成 *-config.cmake 文件(如 fmt-config.cmake),供 find_package() 使用CMakeToolchain 生成 conan_toolchain.cmake,统一传递编译器、架构、标准等设置cmake_minimum_required(VERSION 3.23) project(MyApp)加载 Conan 提供的 toolchain(必须放在 project() 之后、其他命令之前)
set(CMAKE_TOOLCHAIN_FILE $ENV{CONAN_TOOLCHAIN_FILE} CACHE STRING "") if(EXISTS ${CMAKE_TOOLCHAIN_FILE}) include(${CMAKE_TOOLCHAIN_FILE}) endif()
查找并链接 Conan 包
find_package(fmt REQUIRED) add_executable(app main.cpp) target_link_libraries(app fmt::fmt)
将你自己的库发布为 Conan 包,便于团队复用或 CI 统一管理。
conanfile.py 描述包元信息、源码位置、构建逻辑和包结构conan create . --name=mylib --version=1.0.0
conan upload "mylib/1.0.0" -r=my-company --all
conan user -r my
-company -p xxx)且包名/版本符合语义化规则Conan 不是“黑盒”,它的设计围绕可重现性与可审计性展开。只要理清包声明、远程协作、CMake 集成和本地开发流程这四个支点,就能稳定支撑中小型到大型 C++ 工程的依赖治理。不需要一开始就写复杂 conanfile.py,从 conanfile.txt 起步,再逐步引入 profile、lockfile 和私有 remote,节奏更可控。