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 路径搜索逻辑。

银河易创
银河易创

一站式AIGC创作平台,集成GPT-3.5、GPT-4、文心一言等对话模型、Midjourney、DallE等绘画工具、AI音乐、AI视频和AI PPT等功能!

下载
  • 必须用 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)在非标准环境下编译失败率极高。

立即学习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 固化依赖图。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

373

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

436

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

802

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

370

2025.07.23

location.assign
location.assign

在前端开发中,我们经常需要使用JavaScript来控制页面的跳转和数据的传递。location.assign就是JavaScript中常用的一个跳转方法。通过location.assign,我们可以在当前窗口或者iframe中加载一个新的URL地址,并且可以保存旧页面的历史记录。php中文网为大家带来了location.assign的相关知识、以及相关文章等内容,供大家免费下载使用。

232

2023.06.27

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1496

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1169

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

835

2023.08.01

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

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

共48课时 | 10.5万人学习

Git 教程
Git 教程

共21课时 | 4.1万人学习

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

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