0

0

如何在VSCode中配置C++编译与调试环境?【教程】

夜晨

夜晨

发布时间:2026-01-20 23:05:31

|

142人浏览过

|

来源于php中文网

原创

VSCode C++开发需手动配置工具链和JSON文件:先安装g++/clang++与GDB/LLDB并加入PATH,再生成修正tasks.json(含-g、-std)和launch.json(核对program、miDebuggerPath、externalConsole),最后通过C/C++扩展配置c_cpp_properties.json以支持智能提示。

如何在vscode中配置c++编译与调试环境?【教程】

VSCode 本身不内置 C++ 编译器或调试器,必须手动配置外部工具链和调试适配器;直接点击“运行”按钮必然失败,核心在于正确生成 tasks.jsonlaunch.json 并确保 g++clang++ 在系统 PATH 中可访问。

确认并安装基础工具链(Windows/macOS/Linux 通用)

VSCode 的 C++ 支持完全依赖你本地已安装的编译器和 GDB/LLDB。没装好这些,后续所有 JSON 配置都是空转。

  • Windows:安装 MinGW-w64(推荐 官方构建版)或 Visual Studio Build Tools(含 cl.exe),并把 bin/ 目录加进系统 PATH;验证运行 g++ --versioncl
  • macOS:用 brew install llvmclang++lldb,或 Xcode 命令行工具(xcode-select --install
  • Linux:通常自带 g++gdb,若无则 sudo apt install build-essential gdb(Ubuntu/Debian)

生成 tasks.json:让 Ctrl+Shift+B 能真正编译

tasks.json 定义“构建任务”,它不自动创建,必须通过 VSCode 命令触发生成,且需手动修正编译器路径、标准和输出位置——否则默认模板常指向不存在的 g++ 或忽略 -std=c++17 等关键参数。

  • 在打开的 C++ 文件中按 Ctrl+Shift+P → 输入 “Tasks: Configure Default Build Task” → 选 “C/C++: g++.exe build active file”(Windows)或 “C/C++: clang++ build active file”(macOS/Linux)
  • 打开生成的 .vscode/tasks.json,检查 args 数组:确保包含 "-g"(生成调试信息)、"-std=c++17"(按需调整)、"-o" 输出到 "${fileDirname}/${fileBasenameNoExtension}"
  • 若用 MSVC(cl.exe),需替换整个 command"cl.exe",并用 /Zi /EHsc /Fe: 替代 GCC 参数;此时 args 里不能有单连字符(如 -o

配置 launch.json:F5 启动调试前必须填对的三项

launch.json 控制调试器行为,最常见失败原因是 program 路径错误、miDebuggerPath 指向不存在的 GDB、或 externalConsole 在 Windows 上设为 false 导致输入卡死。

InsCode
InsCode

InsCode 是CSDN旗下的一个无需安装的编程、协作和分享社区

下载

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

  • Ctrl+Shift+P → “Debug: Open launch.json” → 选 “C++ (GDB/LLDB)” → “g++.exe” 或 “clang++”
  • 关键字段必须手动核对:
    • "program":值应为编译后可执行文件的绝对路径,例如 "${fileDirname}/${fileBasenameNoExtension}"(注意:没有 .exe 后缀,Windows 下 VSCode 会自动补)
    • "miDebuggerPath":Windows MinGW 用户填 "C:\\mingw64\\bin\\gdb.exe"(路径用双反斜杠),macOS 填 "/opt/homebrew/bin/lldb""lldb"(若已加入 PATH)
    • "externalConsole":Windows 下建议设为 true,否则控制台输入会被阻塞;Linux/macOS 可设 false 使用集成终端
  • 调试时若报错 “Unable to start debugging”,优先检查 program 文件是否存在、是否被杀毒软件锁定、以及 gdb 是否能从命令行直接运行

C++ 扩展与 c_cpp_properties.json 的隐性影响

微软官方 C/C++ 扩展(ms-vscode.cpptools)不是可选插件,它提供智能提示、跳转和头文件索引,而 c_cpp_properties.json 决定这些功能能否识别你的标准库路径和宏定义——写 #include 报红?大概率是这里没配好。

  • Ctrl+Shift+P → “C/C++: Edit Configurations (UI)” 自动生成该文件
  • 重点检查 "browse.path":Windows MinGW 应包含 "C:/mingw64/x86_64-w64-mingw32/include/c++" 等路径;macOS Clang 则需 "/opt/homebrew/opt/llvm/include/c++/v1"
  • "defines" 可添加项目级宏(如 "DEBUG"),避免每次编译手动传 -DDEBUG
  • 修改后务必重启 VSCode 窗口,否则 IntelliSense 不刷新

真正卡住人的往往不是 JSON 语法,而是编译器路径拼写错误、GDB 版本太老不支持新 ABI、或者 Windows 杀软静默拦截了 gdb.exe 的调试权限——建议先在终端里手动跑通 g++ -g hello.cpp -o hello && gdb ./hello,再回到 VSCode。

相关专题

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

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

413

2023.08.07

json是什么
json是什么

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

533

2023.08.23

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

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

310

2023.10.13

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

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

75

2025.09.10

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

220

2023.12.07

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

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

621

2023.07.26

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

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

1104

2023.07.27

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

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

792

2023.08.01

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

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

精品课程

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

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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