news 2026/5/1 7:55:12

如何快速在 VS2026 上使用 C++ 模块 — 完整上手指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何快速在 VS2026 上使用 C++ 模块 — 完整上手指南

如何快速在 VS2026 上使用 C++ 模块 — 完整上手指南

前言

现代C++提出了一个非常breakthrough的特性,就是模块,尽管有一些时间的发展了(这个玩意是C++20出的),目前在一些demo case中,VS对模块的支持还OK。笔者也计划试一试逐步开始尝试向自己的一些玩具项目引入module来化简自己工程的依赖处理关系。


为什么要用模块

C++ 模块(C++20)是为了替代传统头文件的一种编译单位机制,在之前,我们如果一个源文件发生更改,这个源文件都需要被全部重新编译,但是模块的增量编译分析到了二进制ABI层次,MSVC的模块(是的,跟其他编译器的厂商实际上不太互通)通过模块二进制接口/BMI 缓存编译产物,而且,这一次的导出更加的健壮,之后我们会介绍两个关键字来告诉你模块的导入和导出是如何工作的。


先决条件

现在VS2022开始下不到了(至少不太好搞到),这就是为什么笔者采用VS2026了。要在 VS2026 上顺利使用模块,请确认以下项目:

  1. Visual Studio 2026(或更新)已安装,并包含 “Desktop development with C++” 工作负载。VS2026 附带 MSVC Build Tools v14.50(IDE 18.0),对模块和语言兼容性有进一步改进。所以现在可以说没啥负担,不用单独开启什么实验特性了,早入正了。
  2. C++ 标准设置:项目或命令行使用/std:c++20或更保守地/std:c++latest(VS2026 的 MSVC 提供对模块的更完整支持)。不过别担心,VS2026默认就是上面的选项,不用改,你怕的话就看一眼就好了

最小可运行示例(代码与逐步说明)

创建一个小工程vs2026-modules-demo/,包含两个文件:

math.ixx(模块接口单元):

exportmodule math;exportintadd(inta,intb){returna+b;}exportstructPoint{intx,y;};

main.cpp(使用模块):

import std;import math;intmain(){std::print("Add Result: {}",add(1,2));Point p{1,2};std::print("Point p ({}, {})\n",p.x,p.y);return0;}

说明:MSVC 社区中.ixx是常见的模块接口扩展名;你也可以使用.cppm等,但 IDE/工具链对扩展名的默认识别可能不同。


在 Visual Studio IDE(VS2026)中使用模块 — 步骤

Visual Studio 已把大部分模块构建细节交给 MSBuild/IDE 去管理,你通常只需把文件加入项目:

  1. 新建项目Console App (C++)(选择 Desktop development with C++ workload)。
  2. 把模块文件加入项目:右键项目 → Add → Existing Item → 添加math.ixxmain.cpp
  3. 确认语言设置:右键项目 → Properties → C/C++ → Language →C++ Language Standard选择ISO C++20或者是以上( 选择Preview也是可以的),同时,还要再 Properties → C/C++ → Language中开启将生成C++23的标准库模块选择为是
  4. 构建并运行:IDE 会自动对模块源进行扫描、生成 BMI、并正确设置编译与链接次序;你通常不需要手动指定.obj。如果模块间依赖复杂(跨项目),可以使用项目引用或在 Project Properties 中配置 Module References。

Reference

  • C++ 中的命名模块教程 | Microsoft Learn
  • 教程:使用命令行中的模块导入标准库 (STL)(C++) | Microsoft Learn
  • Standard C++20 Modules support with MSVC in Visual Studio 2019 version 16.8 - C++ Team Blog
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/25 18:29:22

Qwen3-14B-Base:阿里巴巴开源大模型的多语言与推理能力跃升

导语 【免费下载链接】Qwen3-14B-Base 项目地址: https://ai.gitcode.com/hf_mirrors/Qwen/Qwen3-14B-Base 阿里巴巴最新发布的Qwen3-14B-Base大模型以36万亿tokens训练数据和119种语言支持,重新定义了开源模型的性能边界,在企业级应用与消费级场…

作者头像 李华
网站建设 2026/5/1 6:56:37

跨平台WebAssembly开发:Emscripten兼容性深度解析与实战方案

跨平台WebAssembly开发:Emscripten兼容性深度解析与实战方案 【免费下载链接】emscripten Emscripten: An LLVM-to-WebAssembly Compiler 项目地址: https://gitcode.com/gh_mirrors/em/emscripten WebAssembly技术虽已成熟,但在真实跨平台部署中…

作者头像 李华
网站建设 2026/4/23 21:10:23

超实用屏幕共享工具Bananas:新手也能快速上手

超实用屏幕共享工具Bananas:新手也能快速上手 【免费下载链接】bananas Bananas🍌, Cross-Platform screen 🖥️ sharing 📡 made simple ⚡. 项目地址: https://gitcode.com/gh_mirrors/ba/bananas 在远程办公和在线学习…

作者头像 李华
网站建设 2026/4/23 17:27:56

一键搜图神器:Search By Image完整使用指南

一键搜图神器:Search By Image完整使用指南 【免费下载链接】Search-By-Image Search By Image | 以图搜图 项目地址: https://gitcode.com/gh_mirrors/sea/Search-By-Image 还在为找不到图片来源而烦恼吗?Search By Image这款强大的图像搜索工具…

作者头像 李华
网站建设 2026/5/1 2:44:24

34、《Bash 编辑器命令与功能全解》

《Bash 编辑器命令与功能全解》 在使用Bash shell时,掌握高效的编辑命令和功能对于提高工作效率至关重要。本文将详细介绍emacs模式命令、vi控制模式命令、可加载内置命令以及可编程补全功能。 1. emacs模式命令 emacs模式提供了一系列强大的编辑命令,以下是部分常用命令及…

作者头像 李华
网站建设 2026/4/23 12:33:02

ATX自动化测试工具:终极免费跨平台解决方案

ATX自动化测试工具:终极免费跨平台解决方案 【免费下载链接】ATX Smart phone automation tool. Support iOS, Android, WebApp and game. 项目地址: https://gitcode.com/gh_mirrors/at/ATX ATX(AutomatorX)是网易游戏团队开发的智能…

作者头像 李华