0

0

如何使用Conan为c++项目管理依赖包 C/C++包管理器入门【工程实践】

冰火之心

冰火之心

发布时间:2025-12-20 17:15:36

|

137人浏览过

|

来源于php中文网

原创

Conan是成熟灵活的跨平台C++依赖管理工具,核心在于包定义、远程仓库、本地缓存和配置四环节;支持conanfile.txt/.py声明依赖,集成CMake生成标准文件,并可创建上传自定义包。

如何使用conan为c++项目管理依赖包 c/c++包管理器入门【工程实践】

Conan 是 C++ 项目中成熟、灵活且跨平台的依赖管理工具,它不依赖构建系统(CMake/Make/Ninja 等均可),能统一管理头文件、静态库、动态库、构建脚本等二进制产物。用好 Conan 的关键在于理解 包定义(conanfile.py 或 conanfile.txt)、远程仓库(remote)、本地缓存(cache)和配置(profile) 四个核心环节。

1. 初始化项目并声明依赖(conanfile)

在项目根目录创建 conanfile.txt(适合简单项目)或 conanfile.py(推荐用于需要自定义逻辑的项目)。

  • conanfile.txt 示例:简洁声明依赖和构建设置
[requires]
fmt/10.2.1
openssl/3.2.1

[generators] CMakeDeps CMakeToolchain

[layout] cmake_layout

  • conanfile.py 示例:支持版本逻辑、条件依赖、自定义构建步骤
from conan import ConanFile
from conan.tools.cmake import cmake_layout

class 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")

2. 配置远程仓库与下载依赖

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 强制使用预编译包

3. 在 CMake 中集成 Conan 生成的文件

Conan 通过 CMakeDepsCMakeToolchain 生成标准 CMake 文件,让 CMake 原生识别 Conan 包。

奇布塔
奇布塔

基于AI生成技术的一站式有声绘本创作平台

下载

立即学习C++免费学习笔记(深入)”;

  • CMakeDeps 生成 *-config.cmake 文件(如 fmt-config.cmake),供 find_package() 使用
  • CMakeToolchain 生成 conan_toolchain.cmake,统一传递编译器、架构、标准等设置
  • CMakeLists.txt 中只需两行即可接入:
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)

4. 创建并上传自己的包(conan create / conan upload)

将你自己的库发布为 Conan 包,便于团队复用或 CI 统一管理。

  • 编写 conanfile.py 描述包元信息、源码位置、构建逻辑和包结构
  • 本地测试打包:conan create . --name=mylib --version=1.0.0
  • 上传到远程:conan upload "mylib/1.0.0" -r=my-company --all
  • 注意:上传前确保 remote 已登录(conan user -r my-company -p xxx)且包名/版本符合语义化规则

Conan 不是“黑盒”,它的设计围绕可重现性与可审计性展开。只要理清包声明、远程协作、CMake 集成和本地开发流程这四个支点,就能稳定支撑中小型到大型 C++ 工程的依赖治理。不需要一开始就写复杂 conanfile.py,从 conanfile.txt 起步,再逐步引入 profile、lockfile 和私有 remote,节奏更可控。

相关专题

更多
http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2025

2024.08.16

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

28

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

378

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

115

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

9

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.6万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号