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

如何快速在 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(模块接口单元):

export module math;exportintadd(int a,int b){return a + b;}exportstructPoint{int x, 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

Read more

江湖路远,代码为剑:2025,我与 AI 的问道之旅

江湖路远,代码为剑:2025,我与 AI 的问道之旅

🌞欢迎来到人工智能的世界  🌈博客主页:卿云阁 💌欢迎关注🎉点赞👍收藏⭐️留言📝 🌟本文由卿云阁原创! 📆首发时间:🌹2026年1月1日🌹 ✉️希望可以和大家一起完成进阶之路! 目录 📜 章节一:【开篇·自报家门】 📜 章节二:【卷一·修行之路(个人成长)】 📜 章节三:【卷二·阁中史册(年度创作回顾)】 📜 章节四:【卷三·阴阳之道(生活与博客平衡)】 📜 章节五:【卷五·剑指苍穹(未来展望)】 📜 章节六:【尾声·拱手谢礼】 📜 章节一:【开篇·自报家门】  ▲大家好呀,这是我第一参加博客之星的活动,先做一个简单的介绍吧!       💡大家好,这里是卿云阁。 作为一名🏫果壳大学的研一在校生,我的 2025 年充满了挑战 与蜕变。2025年可以说是我成长速度最快的一年。站在年末的节点回望,

By Ne0inhk
Flutter 组件 deepseek 的适配 鸿蒙Harmony 实战 - 驾驭国产最强大模型 API、实现鸿蒙端 AI 原生对话与流式渲染的高效集成方案

Flutter 组件 deepseek 的适配 鸿蒙Harmony 实战 - 驾驭国产最强大模型 API、实现鸿蒙端 AI 原生对话与流式渲染的高效集成方案

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 deepseek 的适配 鸿蒙Harmony 实战 - 驾驭国产最强大模型 API、实现鸿蒙端 AI 原生对话与流式渲染的高效集成方案 前言 在 AI 浪潮席卷全球的今天,大模型(LLM)已成为移动应用创新的核心引擎。而在众多的国产模型中,DeepSeek 凭借其卓越的算法效率和极致的性价比,正成为开发者们的“真香”选择。 将 DeepSeek 这种顶尖的认知能力,植入到全面拥抱智能化、万物互联的鸿蒙(OpenHarmony)系统中,将碰撞出怎样的火花? deepseek 库为 Flutter 提供了极简的 API 封装,它完美支持了 SSE(流式事件流)响应,能让你的鸿蒙 App

By Ne0inhk
AI Agent 架构:基础组成模块深度解析

AI Agent 架构:基础组成模块深度解析

AI Agent 架构:基础组成模块深度解析 📝 本章学习目标:本章是入门认知部分,帮助零基础读者建立对AI Agent的初步认知。通过本章学习,你将全面掌握"AI Agent 架构:基础组成模块深度解析"这一核心主题。 一、引言:为什么这个话题如此重要 在AI Agent快速发展的今天,AI Agent 架构:基础组成模块深度解析已经成为每个开发者和研究者必须了解的核心知识。无论你是技术背景还是非技术背景,理解这一概念都将帮助你更好地把握AI时代的机遇。 1.1 背景与意义 💡 核心认知:AI Agent正在从"对话工具"进化为"执行引擎",能够主动完成任务、调用工具、与外部世界交互。这一变革正在深刻改变我们的工作和生活方式。 从2023年AutoGPT的横空出世,到如今百花齐放的Agent生态,短短一年多时间,执行式AI已经从概念走向落地。根据最新统计,

By Ne0inhk
人工智能:扩散模型(Diffusion Model)原理与图像生成实战

人工智能:扩散模型(Diffusion Model)原理与图像生成实战

人工智能:扩散模型(Diffusion Model)原理与图像生成实战 1.1 本章学习目标与重点 💡 学习目标:掌握扩散模型的核心原理、前向扩散与反向扩散过程,以及基于扩散模型的图像生成任务实战流程。 💡 学习重点:理解扩散模型的噪声添加与噪声消除机制,学会使用 PyTorch 搭建 DDPM 模型,完成手写数字图像生成任务。 1.2 扩散模型的核心思想 1.2.1 为什么需要扩散模型 💡 传统的生成模型(如 GAN)存在训练不稳定、模式崩溃等问题。扩散模型作为一种基于概率的生成模型,通过逐步添加噪声和逐步去除噪声的双向过程,实现了更稳定的训练和更高质量的生成效果。 扩散模型的灵感来源于非平衡热力学,它的核心是将复杂的生成问题拆解为多个简单的马尔可夫链步骤。在图像生成、文本生成、语音合成等领域,扩散模型的表现已经超越了传统生成模型。 1.2.2 扩散模型的基本框架 💡 扩散模型包含两个核心过程:前向扩散过程和反向扩散过程。 1. 前向扩散过程:从真实数据出发,

By Ne0inhk