0

0

C++如何使用vcpkg管理依赖_C++跨平台的C/C++库管理器入门

下次还敢

下次还敢

发布时间:2025-11-24 12:01:46

|

207人浏览过

|

来源于php中文网

原创

vcpkg是微软开发的C/C++库管理工具,支持跨平台自动下载、编译和集成开源库。通过git克隆并运行引导脚本生成可执行文件后,可用search和install命令查找安装依赖,如boost、fmt等,默认静态链接,支持动态库指定后缀。集成到CMake项目时,通过-DCMAKE_TOOLCHAIN_FILE引入toolchain文件,CMake自动处理路径,配合find_package和target_link_libraries使用。推荐在项目根目录创建.vcpkg-root标记和vcpkg.json声明依赖,实现团队与CI环境一致性,结合CMake Presets统一构建配置,使C++依赖管理高效便捷。

c++如何使用vcpkg管理依赖_c++跨平台的c/c++库管理器入门

在C++开发中,手动管理第三方库常常耗时且容易出错。vcpkg 是由微软开发并维护的跨平台 C/C++ 库管理工具,支持 Windows、Linux 和 macOS,能自动下载、编译和集成开源库,极大简化依赖管理流程。

安装 vcpkg

vcpkg 本身是一个开源项目,你可以通过 Git 克隆并构建它:

  • 打开终端或命令行,执行以下命令:
  • git clone https://github.com/microsoft/vcpkg.git
  • 进入 vcpkg 目录并运行引导脚本:
  • cd vpkpg && ./bootstrap-vcpkg.sh(Linux/macOS)
    .\bootstrap-vcpkg.bat(Windows)
  • 完成后会生成 vcpkg 可执行文件,可用于后续操作。

搜索与安装库

使用 vcpkg 安装库非常简单。例如,你想使用 Boost 或 OpenCV:

  • 先搜索可用的库:
  • ./vcpkg search boost
  • 安装指定库(如 boost-system):
  • ./vcpkg install boost-system
  • 支持同时安装多个库:
  • ./vcpkg install fmt spdlog openssl
  • 默认安装的是静态库,若需动态链接库,可加上后缀:
  • ./vcpkg install sqlite3:x64-windows-dynamic

集成到 CMake 工程

大多数现代 C++ 项目使用 CMake,vcpkg 提供了对 CMake 的无缝支持。

Hitems
Hitems

HITEMS是一个AI驱动的创意设计平台,支持一键生成产品

下载

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

  • 在项目根目录的 CMakeLists.txt 同级位置创建一个 main.cpp 测试文件,并编写使用某个库的代码(如 fmt)。
  • 配置 CMake 构建时,通过 -DCMAKE_TOOLCHAIN_FILE 指定 vcpkg 的 toolchain 文件:
  • cmake . -B build -DCMAKE_TOOLCHAIN_FILE=vcpkg/scripts/buildsystems/vcpkg.cmake
  • CMake 会自动找到已安装的库,无需手动设置 include 和 link 路径。
  • 在 CMakeLists.txt 中正常 find_package 即可:
  • find_package(fmt REQUIRED)
    target_link_libraries(your_target PRIVATE fmt::fmt)

项目本地集成(推荐做法)

为确保团队成员和 CI 环境使用相同依赖,建议将 vcpkg 集成到项目中。

  • 在项目根目录下创建 .vcpkg-root 文件(空文件即可),标记此目录为 vcpkg 项目根。
  • 创建 vcpkg.json 文件声明依赖:
  • {
      "name": "my-project",
      "version": "1.0.0",
      "dependencies": [
        "fmt",
        "spdlog"
      ]
    }
  • 运行 ./vcpkg install 会根据 vcpkg.json 自动安装所需库。
  • 配合 CMake Presets 使用更佳,可统一构建配置。

基本上就这些。vcpkg 让 C++ 的依赖管理变得像 npm 或 pip 一样直观。只要配置一次 toolchain,后续添加库只需 install + find_package,跨平台兼容性也由 vcpkg 自动处理。不复杂但容易忽略的是集成路径和 target 名称的写法,查官方 ports 文档最稳妥。基本上用熟了就离不开了。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

406

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

531

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

pip安装使用方法
pip安装使用方法

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

335

2023.10.09

更新pip版本
更新pip版本

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

403

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、保存并关闭文件即可。

748

2024.12.23

python升级pip
python升级pip

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

337

2025.07.23

java学习网站推荐汇总
java学习网站推荐汇总

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

6

2026.01.08

热门下载

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

精品课程

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

共94课时 | 6.3万人学习

C 教程
C 教程

共75课时 | 3.9万人学习

C++教程
C++教程

共115课时 | 11.5万人学习

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

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