VS Code 配置 C/C++ 编程运行环境(保姆级教程)

VS Code 配置 C/C++ 编程运行环境(保姆级教程)

文章目录

在本教程中,将会安装 Visual Studio Code(后简称 VS Code),并在 VS Code 中安装 C/C++ 相关插件, 同时也将 VS Code 配置为使用 MinGW-W64 中的 GCC C/C++ 编译器(gcc/g++)和 GDB 调试器来创建在 Windows 上运行的程序。配置 VS Code 后,你将编写、编译、运行和调试大多数的 C/C++ 程序。

本教程所有参考内容均来自Documentation for Visual Studio Code

一、软件下载

1. 下载 VS Code 安装工具

官方下载链接:Visual Studio Code - Code Editing. Redefined

在这里插入图片描述

直接点“Download for Windows”就可以进行下载。

2. 下载 MinGW-W64

MinGW-W64 可以去MinGW-w64的官网下载,也就可以直接去 MinGW-W64 的 GitHub 上下载。由于在官网下载容易下错,所以我这里给一个 GitHub 的链接,也是在 VS Code 上提供的链接。(官方认证,绝对没错!)

MinGW-W64下载链接:Releases · msys2/msys2-installer (github.com)

进入链接后,可以看到历史版本的更替,截至本教程编写日期,最新版本为 2024-01-13 的版本,单击日期跳转至下载窗口。

在这里插入图片描述

如下图所示,选择msys2-x86_64-20240113.exe(记住前缀是 msys2-x86_64 就行,后面是日期),点击后面的下载标志。

在这里插入图片描述

二、安装 VS Code

双击运行VSCodeUserSetup-x64-1.87.2.exe

在这里插入图片描述

如果出现如下弹窗,单击运行即可。

在这里插入图片描述

选择我同意此协议并单击下一步

在这里插入图片描述

这里提示 VS Code 的安装位置,我只有一个 C 盘(现在的固态硬盘可以选择不分区),所以选择默认默认路径,直接点击下一步。当然,你的电脑硬盘要是有分区的话,可以选择其他路径。

在这里插入图片描述

这一步是创建快捷方式的名字,可以输入其他名字,下面的选项如果不勾选,就会把快捷方式添加到开始菜单中。我选择默认,直接点下一步

在这里插入图片描述

默认只有最后两项被选中,我全部选上,单击下一步

在这里插入图片描述

最后再确认一下信息,确认之后直接安装即可。

在这里插入图片描述

大概一分钟左右就可以安装完成。

在这里插入图片描述

安装完成后,先暂时不运行 VS Code,把勾选去掉,点击完成

在这里插入图片描述

三、安装 MinGW-W64 及配置环境变量

双击msys2-x86_64-20240113.exe运行安装程序。

在这里插入图片描述
[!CAUTION]

请注意,MSYS2 需要 64 位 Windows 8.1 及以上版本。

此界面直接点击下一步

在这里插入图片描述

选择安装的路径,我这里选择默认,同学们可以根据自己的情况修改路径,之后点击下一步

在这里插入图片描述

开始菜单中的名字,这个还是可以直接默认,点击下一步

在这里插入图片描述

开始安装。

在这里插入图片描述

待进度条走完,直接点击下一步

在这里插入图片描述

默认勾选立即运行MSYS2,单击完成

在这里插入图片描述

当按下完成之后,会弹出打开一个 MSYS2 终端窗口。

在这里插入图片描述

在此终端中,通过输入以下命令并按回车键,安装 MinGW-w64 工具链:

pacman -S--needed base-devel mingw-w64-ucrt-x86_64-toolchain 

出现这个界面,直接按回车键,默认接受所有的安装包。

在这里插入图片描述

当系统提示是否继续安装时,请输入y并回车。

在这里插入图片描述

之后就进入安装过程,稍等片刻。

在这里插入图片描述

当所有的包都安装好后,直接关闭终端。

在这里插入图片描述

打开安装 MSYS2 的目录,先找到ucrt64文件夹并进入,再找到bin文件夹并进入,然后在地址栏中,复制路径。

如果一开始用默认路径,那路径就是C:\msys64\ucrt64\bin

在这里插入图片描述

然后在搜索框中输入 编辑系统环境变量,并打开编辑系统环境变量的设置界面。

在这里插入图片描述

在系统属性的弹窗中,点击环境变量

在这里插入图片描述

在弹出的环境变量弹窗中,找到用户变量的Path,并双击打开。

在这里插入图片描述

此时会弹出编辑环境变量的窗口,先点击新建按钮,然后会在空白行中出现一个输入框和一个闪烁的光标,在这里粘贴上广告复制的路径,最后点击确定按钮回到上层弹窗。

在这里插入图片描述

最后逐层弹窗点击确定按钮退出即可。

在这里插入图片描述

最后做一下测试,按组合键Win + r之后,输入cmd回车。

在这里插入图片描述

回车之后,就可以调出 CMD 的终端窗口了,然后分别输入下面的命令,每输入一次命令后回车一次。

gcc --version g++ --version gdb --version 

出现如下图一样的信息,就说明 C/C++ 的编译环境已经安装好。

在这里插入图片描述

四、配置 VS Code 的 C/C++ 编程运行环境

1. 汉化 VS Code(选做)

这个配置环节并不属于 C/C++ 编程运行环境的配置必要环节,先挑战或想适应英文开发环境的同学可以跳过。

考虑到很多同学的英文水平可能不是很好,对于全英文的开发环境会犯难,这里可以使用 VS Code 自带的汉化插件来解决这个问题。

首先启动 VS Code 软件,按下组合键Ctrl + Shift + x,或者直接点击左边的第五个小图标,进入Extensions

在这里插入图片描述

在上方输入框中键入Chinese,扩展插件的列表会刷新出汉化插件,点击对应的Install按钮进行安装。

在这里插入图片描述

安装好后,软件界面的右下角会弹出通知,并附带Change Language and Restart的按钮,点击这个按钮,即可重启软件。

在这里插入图片描述

软件重启后,就是中文的界面了。

在这里插入图片描述

2. 安装 C/C++ 扩展包

Extensions中搜索“C++”,列表第一个扩展包就是我们要的,点击安装即可。

在这里插入图片描述
[!TIP]

上图中的C/C++ Extension Pack是 C/C++ 的扩展功能包,里面包含了一些项目管理和代码构建的工具,不是必要的扩展包,可以选择性安装。

五、测试 VS Code 的 C/C++ 编程环境

1. 创建代码文件夹

VS Code 是一款基于文件夹进行代码编辑和管理的编辑器,通常我们会把新建一个文件夹来管理同一个项目的代码,并在 VS Code 中打开。

我新建了一个名为Code的文件夹,并在里面新建了一个用于专门放 C 语言代码的文件夹。

在这里插入图片描述
[!WARNING]

需要注意的是,这个路径最好不要存在中文,否则会出现编译失败等问题。

打开 VS Code,点击打开文件夹的按钮。

在这里插入图片描述

在弹窗中找到刚刚新建的C文件夹,选中文件夹,再点选择文件夹

在这里插入图片描述

选中文件夹后,在新弹出的窗口中,勾选上信任父文件夹"Documents"中所有文件的作者,再点是,我信任此作者

在这里插入图片描述

文件添加好后,在左边的资源管理器中会出现CODE文件夹以及子文件夹C,把鼠标放在文件夹上面,会出现四个小图标。四个小图标从左往右的作用分别是新建文件新建文件夹刷新资源管理器以及在资源管理器中折叠文件夹

在这里插入图片描述

好了,做到这一步,接下来就可以进行代码的运行和调试了。

2. 单个 .c 文件的运行和调试

为了方便管理代码,我们先选中C文件夹,再点击新建文件夹按钮。

在这里插入图片描述

此时会在C文件夹的下级出现一个输入框,我们新建一个名为test的文件夹。

在这里插入图片描述

鼠标右键test文件夹,在弹出的菜单中选择新建文件

在这里插入图片描述

在输入框中输入我们接下来要进行调试代码文件名,命名为test.c,注意,一定要是 .c 结尾。

在这里插入图片描述

接下来就可以输入一个调试程序了,我的代码如下:

#include<stdio.h>intmain(){for(int i =0; i <5; i++)printf("Hello Grayson~%d\n", i);return0;}

写好测试代码后,点击右上角的调试按钮,这时会弹出调试程序的选项,选择第一个,也是本教程前面安装的 gcc 编译工具。

在这里插入图片描述

这时文件就被编译并执行,如果在右下角弹出如下窗口,点击即可。

在这里插入图片描述

运行结果如图所示。

在这里插入图片描述

如果要进行简单的断点调试,可以在行号前加一个断点,操作也很简单,只需用鼠标左键点一下行号左边的空白处即可。如下图所示,是在第六行处加了一个断点。

在这里插入图片描述

这时再去运行程序,搜索框下面就会出现调试的面板,面板上有六个按钮,分别是继续逐过程单步调试单步跳出重启停止

在这里插入图片描述
[!IMPORTANT]

以下是 VS Code 中的 C 语言代码调试面板功能的解释:继续(Continue):继续执行程序,直到遇到下一个断点或程序结束。逐过程(Step Over):逐行执行当前行,如果当前行是函数调用,则进入该函数并执行完毕。单步调试(Step Into):逐行执行当前行,如果当前行是函数调用,则进入该函数并停在函数内的第一行。单步跳出(Step Out):执行完当前函数的剩余部分,并停在当前函数被调用的下一行。重启(Restart):重新启动程序的调试会话,即从程序的起点开始执行。停止(Stop):停止程序的调试会话,结束调试过程并关闭程序执行。

目前这个程序还不能很好说明以上的调试功能(至少逐过程单步调试单步跳出这三个并不明显),所以在后面的内容将以另一个代码进行演示。

3. 多个 .c 文件的运行与调试

如果想要进行多个 .c 文件编译后的调试,就需要进行一些配置修改。如果进行过一次编译运行,我们会发现在资源管理器的C文件夹下,多出一个.vscode的文件夹,这个文件夹里面有个tasks.json的文件

在这里插入图片描述

这个文件是用于定义任务配置,这些任务可以在 VS Code 中运行,例如编译代码、运行测试、启动调试器等。tasks.json文件是一个 JSON 格式的文件,其中包含了任务的配置信息,包括任务名称、命令、参数等。通过编辑tasks.json文件,我们可以自定义项目中的各种任务,并在 VS Code 中方便地执行这些任务。

当前的 VS Code 的运行效果还不是很理想,双击打开tasks.json文件修改一下编译运行功能。下图是对该 JSON 文件做了部分解释。

在这里插入图片描述

具体修改如下图所示,我注释掉了原来的"${file}",并新增一行"*.c",表示并非指定某一个 .c 文件,而是当前文件夹下所有的 .c 文件。同时也把"${fileDirname}\\${fileBasenameNoExtension}.exe"注释掉,改成"${fileDirname}\\program.exe",那么多个 .c 文件编译之后的可执行文件就是program.exe

在这里插入图片描述

修改好后,按组合键Ctrl + s保存即可。

然后点击左侧的运行与调试,再点击创建launch.json文件

在这里插入图片描述

搜索框会弹出选项,选择C++(GDB/LLDB)

在这里插入图片描述

然后 VS Code 会新建一个 JSON 文件,点击右下角的添加配置,在弹出的下拉菜单中选择C/C++:(gdb)启动

在这里插入图片描述

此时,JSON 文件会多出一些配置信息,需要我们修改的内容如下图所示的红框标志内容。

在这里插入图片描述

修改为下图红框所示内容,“program”后的内容就是前面提到的tasks.json文件中的编译后产生的可执行文件。"miDebuggerPath"后面的则是前面安装的 MinGW-W64 的 gdb 工具的路径。修改后保持关闭。

在这里插入图片描述
[!NOTE]

在复制粘贴 gdb 的路径时,不少小伙伴会忽略掉下图所示的问题。反斜杠是转义字符的作用,应该像上图一样多加一个一个反斜杠才表示路径。

之后,我们进行多文件的编译调试,先在C文件夹下新建一个新的文件夹,我这里命名为test2,并在这个文件夹里面新建三个文件,分别是test.cmax.hmax.c

在这里插入图片描述

代码如下:

max.h

#ifndef__MAX_H__#define__MAX_H__#include<stdio.h>intfindMaxNum(int num1,int num2);#endif// __MAX_H__

max.c

#include"max.h"intfindMaxNum(int num1,int num2){return num1 > num2 ? num1 : num2;}

test2.c

#include<stdio.h>#include"max.h"intmain(){int a =10;int b =20;int c =findMaxNum(a, b);printf("%d\n", c);return0;}

代码写好后,给test2.c的第 8 行代码打一个断点,再点调试按钮旁边的小三角形,在下拉菜单中选择调试C/C++文件

在这里插入图片描述

调试面板依旧是之前的那个。如果点击继续,调试过程会跳到下一个断点,不过我们这个程序只打了一个断点,所以会直接运行到程序结束并退出调试。

在这里插入图片描述

如果点击逐过程,则在不进入函数内部,而是直接输出函数的运行结果,然后跳到下一行。

在这里插入图片描述

如果点击单步调试,则会进入被调用函数的内部,继续点击单步调试会一步一步执行并返回。如果进入函数后,点击单步跳出则直接带着函数的执行结果返回被调用处。

在这里插入图片描述

参考资料

《Running Visual Studio Code on Windows》

《C++ programming with Visual Studio Code》

《Get Started with C++ and MinGW-w64 in Visual Studio Code》

Read more

PHP通过 trace_id 追踪全链路的庖丁解牛

PHP 通过 trace_id 实现全链路追踪(Distributed Tracing),是将一次用户请求在多个服务(Nginx、PHP-FPM、MySQL、Redis、第三方 API) 的核心机制。 它让工程师从“日志大海捞针”升级为“一键穿透故障”,是高可用系统必备能力。 一、核心原理:trace_id 如何串联全链路? 1. 分布式追踪三要素 元素作用示例trace_id唯一标识一次完整请求a1b2c3d4-...span_id标识链路中的一个操作(如 SQL 查询)e5f6g7h8parent_span_id标识父操作(构建调用树)a1b2c3d4 2. 传递机制:上下文透传 * HTTP 层: * 入口:Nginx 生成 trace_id → 透传给

By Ne0inhk
Flutter 组件 dart_nostr 适配鸿蒙 HarmonyOS 实战:去中心化通讯,构建分布式 Relay 订阅与非对称加密架构

Flutter 组件 dart_nostr 适配鸿蒙 HarmonyOS 实战:去中心化通讯,构建分布式 Relay 订阅与非对称加密架构

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 dart_nostr 适配鸿蒙 HarmonyOS 实战:去中心化通讯,构建分布式 Relay 订阅与非对称加密架构 前言 在鸿蒙(OpenHarmony)生态迈向万物智联、涉及去中心化社交(DeSo)、分布式身份(DID)及抵御单点崩溃的通讯环境背景下,如何构建一套不依赖中心化服务器、具备绝对抗审查性且数据主权归属于用户的通讯协议,已成为决定新一代互联网应用“生命力”的关键。在鸿蒙设备这类强调分布式软总线与端侧安全治理的环境下,如果应用依然依赖脆弱的中心化中转机,由于由于网络链路的单一性,极易由于由于“中心节点宕机”导致全球范围内的业务中断。 我们需要一种能够基于简单非对称加密、支持全球 Relay(中继器)分发且具备“无主化”特性的抗毁协议。 dart_nostr 为 Flutter 开发者引入了 Nostr(Notes

By Ne0inhk
【MySQL数据库基础】(五)MySQL 数据类型深度解析:选对类型 = 性能拉满!

【MySQL数据库基础】(五)MySQL 数据类型深度解析:选对类型 = 性能拉满!

前言         在 MySQL 表结构设计中,数据类型的选择是最核心也最容易踩坑的环节。很多开发者随手给字段设为int、varchar(255),看似省事,实则会导致磁盘空间浪费、查询效率低下,甚至出现数据溢出、精度丢失的问题。         选对数据类型的本质,是用最小的存储空间存储符合业务需求的数据,这不仅能节省服务器资源,还能提升索引和查询的效率。本文将从 MySQL 的四大核心数据类型(数值、字符串、日期时间、枚举集合)出发,结合实战案例讲透每种类型的用法、边界、坑点,还有不同场景下的选择技巧,让你从根源上做好表结构设计!下面就让我们正式开始吧! 一、数据类型总览:四大类覆盖所有业务场景         MySQL 提供了丰富的数据类型,按用途可分为数值类型、字符串类型、日期时间类型和特殊字符串类型(ENUM/SET),不同类型对应不同的存储规则和业务场景,核心设计原则是按需选择,宁小勿大。         先看一张核心数据类型分类表,快速建立整体认知: 分类核心类型适用场景数值类型TINYINT/INT/BIGINT/FLOAT/

By Ne0inhk
基于多智能体强化学习的医疗检索增强生成系统研究—MMOA-RAG架构设计与实现

基于多智能体强化学习的医疗检索增强生成系统研究—MMOA-RAG架构设计与实现

1. 引言 医疗AI面临知识更新快(每年PubMed新增100万文献)、专业性强(SNOMED CT含35万临床概念)等挑战。传统RAG系统存在三大局限: 1. 模块目标冲突(检索高召回率 vs 生成高准确性) 2. 动态依赖缺失(查询改写影响检索策略) 3. 医疗合规风险(FDA要求Class II设备错误率<7%) 本研究特点: * 提出四智能体协同架构(查询/检索/过滤/生成) * 设计临床奖励函数 Rclinical=0.6F1+0.3Safety+0.1ExpertR_{clinical}=0.6F_1+0.3Safety+0.1ExpertR

By Ne0inhk