VScode 配置 C/C++ 环境(MinGW) && 编写运行 C/C++ 程序

之前 C/C++ 的 IDE 一直用的是 cb,但是感觉 cb 版本太老并且高亮效果太差,而 Devc++ 使用体验差(尤其是代码补全功能),大一的时候还用过宇宙第一IDE —— Visual Studio,奈何太臃肿了。而以前用 VScode 的主要功能就是预览各种类型的文件以及编写 markdown 文档,不由感叹 VScode 真的太好用!酷炫的各种主题以及高亮显示,还有便捷的代码替换功能,预览功能等等。于是决定在 IDE 方面要抛弃 cb ,选择 VScode。

安装思路:VScode 上有 C/C++ 的拓展插件,但是没有配有 C/C++ 的编译器,需要安装者自行下载,这里我选择的是 Windows 环境下最常见的 MinGW 编译器。MinGW 需配置环境变量,供 VScode 调用。在 VScode 中需创建配置文件(json),设置运行 C/C++ 程序的相关参数。

1 关于VScode

VSCode 是微软发布一款跨平台的源代码编辑器,其拥有强大的功能和丰富的扩展,使之能适合编写许多语言。

官网下载:https://code.visualstudio.com

2 配置MinGW环境变量

2.1 MinGW下载

官网 : http://www.mingw.org

vscode-conf-01

如果你的电脑里也安装了 Codeblocks,可直接使用 Codeblocks 中的 MinGW 编译器,地址在./Codeblocks/MinGW/

例如我的:

vscode-conf-02

2.2 配置环境变量

此电脑 → 右键 → 属性 → 高级系统设置 → 环境变量

vscode-conf-03 vscode-conf-04

将 MinGW 的 bin 文件夹(例如我的:D:\MinGW\bin)路径添加到环境变量 path 中:

vscode-conf-05

vscode-conf-06 vscode-conf-07

2.3 测试是否配置成功

快捷键 win + R 进入 cmd 窗口,输入测试命令:gcc --version

vscode-conf-08

出现如上所示页面即配置成功。

3 VScode相关插件配置

3.1 安装C/C++插件

插件库搜索“C/C++”,选择 “install”:

vscode-conf-09

3.2 配置.vscode相关文件

3.2.1 创建.vscode文件夹

首先在磁盘中创建一个文件夹,作为之后你的所有 C/C++ 代码文件存放的文件夹(即 workspace ),文件夹名字可自主命名,例如我的:Workspace

vscode-conf-010

再将此空文件夹拖入 VScode 中:

vscode-conf-011

在 WorkSpace 文件下创建.vscode文件夹(文件夹名字必须是.vscode),注意目录结构如下图所示:

vscode-conf-012

3.2.2 创建launch.json文件

在 vscode 文件下创建launch.json文件:

vscode-conf-013

launch.json下粘贴如下代码:

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) Launch",	// 配置名称,将会在启动配置的下拉菜单中显示
            "type": "cppdbg", 		// 配置类型,这里只能为cppdbg
            "request": "launch",	// 请求配置类型,可以为launch(启动)或attach(附加)
            "program": "${fileDirname}/${fileBasenameNoExtension}.exe",// 将要进行调试的程序的路径
            "args": [],				// 程序调试时传递给程序的命令行参数,一般设为空即可
            "stopAtEntry": false, 	// 设为true时程序将暂停在程序入口处,一般设置为false
            "cwd": "${workspaceRoot}",// 调试程序时的工作目录,一般为${workspaceRoot}即代码所在目录
            "environment": [],
            "externalConsole": true,// 调试时是否显示控制台窗口,一般设置为true显示控制台
            "MIMode": "gdb",
            "miDebuggerPath": "D:/MinGW/bin/gdb.exe",// miDebugger的路径,注意这里要与MinGw的路径对应
            "preLaunchTask": "g++",	// 调试会话开始前执行的任务,一般为编译程序,c++为g++, c为gcc
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                }
            ]
        }
    ]
}

需要根据你的电脑环境进行修改的选项是"miDebuggerPath",注意路径中斜杠的问题:

vscode-conf-014

注意:有朋友指出在路径中用单斜杠不行,应该和系统有关,建议大家单斜杠和双斜杠都试试,哪个可以用哪个。

3.2.3 创建tasks.json文件

在 VScode 文件下创建tasks.json文件:

vscode-conf-015

tasks.json中粘贴如下代码:

{
    "version": "2.0.0",
    "command": "g++",
    "args": ["-g","${file}","-o","${fileDirname}/${fileBasenameNoExtension}.exe"], // 编译命令参数
    "problemMatcher": {
        "owner": "cpp",
        "fileLocation": ["relative", "${workspaceRoot}"],
        "pattern": {
            "regexp": "^(.*):(\\d+):(\\d+):\\s+(warning|error):\\s+(.*)$",
            "file": 1,
            "line": 2,
            "column": 3,
            "severity": 4,
            "message": 5
        }
    }
}

直接粘贴即可,不需修改

vscode-conf-016

3.2.4 关于launch.json与tasks.json的说明

  • 如想更加个性化地设置 json 文件,可参考 官方文档

  • 至此,环境已经配置完毕,下面开始调试 cpp 文件。

4 调试cpp程序

因为 VScode 不像 IDE(比如 CB,VS 等)在调试的时候黑框下面有点击任意键返回,所以需要手动加一个断点,或者程序最后加一个 system(“pause”) 等,命令窗口才能停留。

4.1 编写代码

#include 
using namespace std;
int main(){
    cout << "hello world" << endl;
    system("pause");
    return 0;
}

vscode-conf-018

4.2 运行程序

快捷键 F5,或点击左边面板的绿色小箭头。

vscode-conf-019

运行结果:

vscode-conf-020

至此,C/C++ 环境在 VScode 中已经配置成功。