0

0

c++怎么配置Conan包管理工具_c++ 跨平台依赖下载与CMake集成【指南】

尼克

尼克

发布时间:2025-12-31 13:46:03

|

461人浏览过

|

来源于php中文网

原创

Conan安装后conan --version报command not found主因是PATH未生效:Windows需重启终端或手动加Scripts路径,macOS/Linux需将~/.local/bin加入shell配置并重载;用conanfile.txt声明依赖时需配置[requires]和[generators],运行conan install --build=missing生成CMake所需文件;find_package(fmt)失败因Conan生成CONFIG模式文件,须用find_package(fmt CONFIG REQUIRED)并确保CMAKE_PREFIX_PATH包含deps目录;跨平台构建卡住常因无匹配预编译包而触发本地编译,应优先查可用二进制、用--build=never或调整settings避免编译。

c++怎么配置conan包管理工具_c++ 跨平台依赖下载与cmake集成【指南】

Conan 安装后为什么 conan --version 报 command not found?

多数情况是 PATH 没生效。Windows 上用 Chocolatey 或 Scoop 安装后需重启终端;macOS/Linux 用 pip 安装时,conan 可能落在 ~/.local/bin,而该路径未被 shell 加载。

  • 检查安装位置:python -m pip show conan → 看 LocationFiles
  • Linux/macOS:把 export PATH="$HOME/.local/bin:$PATH" 加进 ~/.bashrc~/.zshrc,再执行 source ~/.zshrc
  • Windows:确认安装时勾选了 “Add Conan to PATH”,否则手动把 C:\Users\{user}\AppData\Roaming\Python\PythonXX\Scripts 加入系统环境变量

如何用 conanfile.txt 声明依赖并生成 conanbuildinfo.cmake

这是最轻量的集成方式,适合已有 CMake 项目的快速接入。Conan 不接管构建,只负责下载 + 生成 CMake 可读的配置文件。

  • 在项目根目录建 conanfile.txt,内容示例:
[requires]
fmt/10.2.1
spdlog/1.13.0

[generators]
CMakeDeps
CMakeToolchain
  • 运行:conan install . --build=missing --settings compiler.cppstd=17
  • 注意:--build=missing 是关键,否则遇到预编译包不匹配(如 macOS M1 vs Intel)会直接报错退出
  • 生成的 conan_toolchain.cmakexxx-deps.cmake 文件默认输出到当前目录,CMake 需显式加载:cmake -DCMAKE_TOOLCHAIN_FILE=conan_toolchain.cmake ...

为什么 CMakeLists.txt 里 find_package(fmt) 找不到,但 find_package(fmt CONFIG) 可以?

因为 Conan 的 CMakeDeps 生成的是 CONFIG 模式文件(即 fmtConfig.cmake),它不走 CMake 默认的 FindXXX.cmake 路径搜索逻辑。

  • 必须用 find_package(fmt CONFIG REQUIRED),且确保 CMAKE_PREFIX_PATH 包含 Conan 生成的 deps 目录(通常由 conan_toolchain.cmake 自动注入)
  • 如果仍失败,检查 conan install 输出末尾是否提示 Generated xxx-config.cmake,没有说明 CMakeDeps 未生效或包本身不提供 cmake targets
  • 旧项目若坚持用 find_package(fmt),可临时加一层兼容:include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake) + conan_basic_setup()(仅限 legacy conanbuildinfo.cmake 方式)

跨平台构建时 conan install 总卡在某个包的 build 阶段

根本原因是 Conan 默认按 host 设置(OS/arch/compiler)匹配预编译二进制,一旦官方仓库没提供对应组合(比如 Windows + clang + static CRT),就会 fallback 到本地编译——而很多 C++ 包(如 OpenSSL、Boost)在非标准环境下编译失败率极高。

Endel.io
Endel.io

Endel是一款可以创造个性化舒缓声音的应用程序,可帮助您集中注意力、放松身心和入睡。

下载

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

  • 先查可用二进制:conan search fmt/10.2.1 -r conancenter,看输出中是否有匹配你 --settings 的行
  • 避免编译:加 --build=never 强制只用二进制;或指定更通用的 settings,例如把 compiler.runtimeMT 改成 MD(Windows 动态链接 CRT)
  • 真要编译:确保已安装对应工具链(如 MinGW 工具链需提前配好 CONAN_CMAKE_GENERATORCONAN_CMAKE_TOOLCHAIN_FILE

真正麻烦的从来不是“怎么让 Conan 下载”,而是“怎么让它别自己编译”。每个包的编译脚本质量参差不齐,尤其涉及汇编或平台特有 ABI 时,本地编译极易失败。建议优先锁定已验证的二进制版本,再通过 conan lock 固化依赖图。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

715

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

625

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

739

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1235

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

575

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

698

2023.08.11

小游戏4399大全
小游戏4399大全

4399小游戏免费秒玩大全来了!无需下载、即点即玩,涵盖动作、冒险、益智、射击、体育、双人等全品类热门小游戏。经典如《黄金矿工》《森林冰火人》《狂扁小朋友》一应俱全,每日更新最新H5游戏,支持电脑与手机跨端畅玩。访问4399小游戏中心,重温童年回忆,畅享轻松娱乐时光!官方入口安全绿色,无插件、无广告干扰,打开即玩,快乐秒达!

30

2025.12.31

热门下载

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

精品课程

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

共48课时 | 6.3万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

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

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