vscode C/C++环境搭建


C/C++环境我配置过好几次,刚开始不太会,一直失败,要么就是配置好以后用过一段时间用起来不太舒服。经过查看别人的配置,外加一丢丢自己的改动,尝试N次之后终于用起来比较舒服了,特此记录与分享一下。

安装vscode

直接进入vscode官网下载安装即可。

安装编译器

可以安装MinGw或mingw64,我选择了mingw64,这两个也是直接官网下载即可。
安装好之后将编译器的bin目录添加至系统环境变量。

安装插件

  • 中文插件

vscode默认是英文,点击左侧插件栏,然后搜索Chinese,安装此插件,安装后重新载入vscode,这时vscode的所有语言变为中文。
在这里插入图片描述

  • C/C++插件

安装C/C++插件,步骤同上。
在这里插入图片描述

  • code runner

安装code runner插件,步骤同上。
在这里插入图片描述
安装该插件后,右上角会多出一个运行按钮,这时点击该按钮,或者右键编辑区域,再或者Ctrl+Alt+N都可以运行程序。
在这里插入图片描述
点击运行。
在这里插入图片描述

配置C/C++环境

首先新建一个文件夹,将该文件夹作为工作区。在此文件夹内添加一个**.vscode**文件夹,在其中添加相关配置文件。

  • tasks.json
{
    "version": "2.0.0",
    "command": "g++",
    "args": [
        "-g",               // 生成和调试有关的信息
        "${file}",
        "-std=c++11",
        "-Wall",            // 开启额外警告
        "-static-libgcc",   // 静态链接libgcc,一般都会加上
        "-o",
        "${fileBasenameNoExtension}.exe"
    ], // 编译命令参数
    "problemMatcher": {
        "owner": "cpp",
        "fileLocation": [
            "relative",
            "${workspaceFolder}"
        ],
        "pattern": {
            "regexp": "^(.*):(\\d+):(\\d+):\\s+(warning|error):\\s+(.*)$",
            "file": 1,
            "line": 2,
            "column": 3,
            "severity": 4,
            "message": 5
        }
    },
    "presentation": {
        "echo": true,
        "reveal": "always",     // 执行任务时是否跳转到终端面板,可以为always,silent,never。
        "focus": false,         // 设为true后可以使执行task时焦点聚集在终端,但对编译C/C++来说,设为true没有意义
        "panel": "shared",      // 不同的文件的编译信息共享一个终端面板
        "showReuseMessage": true,
        "clear": false
    }
 }
  • launch.json
{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) Launch", // 配置名称,将会在启动配置的下拉菜单中显示
            "type": "cppdbg", // 配置类型,这里只能为cppdbg
            "request": "launch", // 请求配置类型,可以为launch(启动)或attach(附加)
            "program": "${workspaceFolder}/${fileBasenameNoExtension}.exe", // 将要进行调试的程序的路径
            "args": [], // 程序调试时传递给程序的命令行参数,一般设为空即可
            "stopAtEntry": false, // 设为true时程序将暂停在程序入口处,一般设置为false
            "cwd": "${workspaceFolder}", // 调试程序时的工作目录,一般为${workspaceRoot}即代码所在目录 workspaceRoot已被弃用,现改为workspaceFolder
            "environment": [],
            "externalConsole": false, // 调试时是否显示控制台窗口,一般设置为true显示控制台
            "internalConsoleOptions": "neverOpen",
            "MIMode": "gdb",
            "miDebuggerPath": "F:/mingw64/bin/gdb.exe", // miDebugger的路径,注意这里要与MinGw的路径对应
            "preLaunchTask": "g++", // 调试会话开始前执行的任务,一般为编译程序,c++为g++, c为gcc
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": false
                }
            ]
        }
    ]
}
  • settings.json
{
    "files.associations": {
        "cmath": "cpp",
        "iostream": "cpp",
        "new": "cpp",
        "*.tcc": "cpp",
        "ostream": "cpp",
        "sstream": "cpp",
        "array": "cpp",
        "cctype": "cpp",
        "clocale": "cpp",
        "cstdint": "cpp",
        "cstdio": "cpp",
        "cstdlib": "cpp",
        "cstring": "cpp",
        "ctime": "cpp",
        "cwchar": "cpp",
        "cwctype": "cpp",
        "deque": "cpp",
        "unordered_map": "cpp",
        "vector": "cpp",
        "exception": "cpp",
        "fstream": "cpp",
        "functional": "cpp",
        "initializer_list": "cpp",
        "iomanip": "cpp",
        "iosfwd": "cpp",
        "istream": "cpp",
        "limits": "cpp",
        "stdexcept": "cpp",
        "streambuf": "cpp",
        "system_error": "cpp",
        "type_traits": "cpp",
        "tuple": "cpp",
        "typeinfo": "cpp",
        "utility": "cpp",
        "atomic": "cpp",
        "bitset": "cpp",
        "cfenv": "cpp",
        "chrono": "cpp",
        "cinttypes": "cpp",
        "codecvt": "cpp",
        "complex": "cpp",
        "condition_variable": "cpp",
        "csetjmp": "cpp",
        "csignal": "cpp",
        "cstdarg": "cpp",
        "cstddef": "cpp",
        "cuchar": "cpp",
        "forward_list": "cpp",
        "list": "cpp",
        "unordered_set": "cpp",
        "future": "cpp",
        "memory": "cpp",
        "mutex": "cpp",
        "numeric": "cpp",
        "ratio": "cpp",
        "scoped_allocator": "cpp",
        "shared_mutex": "cpp",
        "thread": "cpp",
        "typeindex": "cpp",
        "valarray": "cpp",
        "map": "cpp",
        "memory_resource": "cpp",
        "optional": "cpp",
        "string_view": "cpp",
        "random": "cpp"
    },
    "files.defaultLanguage": "cpp", // ctrl+N新建文件后默认的语言
    "editor.formatOnType": true, // (对于C/C++)输入分号后自动格式化当前这一行的代码
    "editor.acceptSuggestionOnEnter": "off", // 我个人的习惯,按回车时一定是真正的换行,只有tab才会接受Intellisense
    "code-runner.runInTerminal": true, // 设置成false会在“输出”中输出,无法输入
    "code-runner.saveFileBeforeRun": true, // run code前保存
    "code-runner.preserveFocus": true, // 若为false,run code后光标会聚焦到终端上。如果需要频繁输入数据可设为false
    "code-runner.clearPreviousOutput": false,
    "C_Cpp.intelliSenseEngine": "Default",
}
  • c_cpp_properties.json
{
    "configurations": [
        {
            "name": "Win32",
            "includePath": [
                "${workspaceFolder}"
            ],
            "defines": [
                "_DEBUG",
                "UNICODE",
                "_UNICODE"
            ],
            "compilerPath": "F:\\mingw64\\bin\\g++.exe",
            "intelliSenseMode": "${default}",
            "browse": {
                "path": [
                    "${workspaceFolder}"
                ],
                "limitSymbolsToIncludedHeaders": true,
                "databaseFilename": ""
            },
            "cStandard": "c11",
            "cppStandard": "c++17"
        }
    ],
    "version": 4
}

使用及调试

配置好之后,再编写程序,编辑器就能够进行智能提示。
在这里插入图片描述
接下来试一试调试功能。

  • 设置断点

在这里插入图片描述

  • F5进入调试功能。

在这里插入图片描述

常用插件

  • Bracket Pair Colorizer
    该插件会将括号标注为不同的颜色,在编写代码时更加容易区分。
  • vscode-icons
    一个美化包,能够改变每种文件名前的图标。
  • TabNine
    一种非常强大的代码补全工具,支持23种编程语言,这种插件会根据程序员过去的习惯自动补全,便在后面给出几种选项的概率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值