VSCode配置WSL的C++环境(在VSCode通过WSL调试C++)

1、安装wsl需要的环境 如果已经有了,不需要安装

sudo apt-get install gcc g++ -y

2、查看gcc g++的位置

whereis g++
whereis gdb

3、创建工程目录,创建个目录然后在那个目录下执行code . 就会打开vscode

mkdir cpp
cd cpp
code .

4、编辑配置,键入Ctrl + Shift + P打开命令面板。输入C/C++ edit configurations,选择UI的直观简单些 贴个图,照着图上的搞就行了

5、创建Tasks,Ctrl + Shift + P打开命令面板,选择任务:配置默认生成任务使用模板创建tasks.json文件

 6、将里面的内容全部替换成下面的内容

{
    "version": "2.0.0",
    "windows": {
        "options": {
            "shell": {
                "executable": "bash.exe",
                "args": [
                    "-c"
                ]
            }
        }
    },
    "tasks": [
        {
            "label": "g++ build active file",
            "type": "shell",
            "command": "/usr/bin/g++",
            "args": [
                "-g",
                "${file}",
                "-o",
                "${fileDirname}/${fileBasenameNoExtension}"
            ],
            "group": {
                "kind": "build",
                "isDefault": true
            }
        }
    ]
}

7、开始调试运行,写一个C++文件,按F5就可以开始调试

#include <stdio.h>
#include <windows.h>
int main()
{
    printf("Hello World\n");
    system("pause");
    return 0;
}

完美运行就OK

### 配置 VSCode 使用 WSL 进行 C/C++ 开发 #### 工具准备 为了在 Windows 上使用 Linux 子系统 (WSL) 和 Visual Studio Code 构建高效的 C/C++ 编程环境,需先完成以下准备工作: - **安装并配置 WSL**: 可按照官方文档指导,在 Windows 中启用 WSL 功能,并选择合适的 Linux 发行版进行安装[^1]。 - **更新软件包列表及安装必要组件**: ```bash sudo apt update && sudo apt upgrade -y ``` - **安装 GCC/G++, GDB 调试器及其他依赖项**: ```bash sudo apt install -y build-essential gdb cmake ``` 以上操作确保了基础构建工具链的存在,这对于后续编写、编译和调试程序至关重要[^4]。 #### 设置 VSCode 支持 WSL 的工作区 一旦上述步骤顺利完成,则可以着手于集成 VSCode 来增强开发体验: - 打开 VSCode 并访问 Extensions 市场, 搜索 `Remote - WSL` 插件并点击 Install 安装该扩展。此功能允许开发者直接从编辑器内部启动基于 WSL 的终端会话,从而实现无缝衔接的工作流程[^2]。 - 推荐同时安装其他辅助性的插件如 "C/C++" by Microsoft 或者类似的语法高亮显示/智能感知服务提供者,以便更好地支持特定编程语言特性。 #### 创建项目结构与初始化 Git 版本控制 建议创建一个新的文件夹用于存放源码文件,并考虑初始化 git 库来跟踪变更历史记录: ```bash mkdir ~/my_cpp_project && cd $_ git init . ``` 接着可以通过右键菜单选项打开当前目录为新的 VSCode 实例窗口,此时应当自动切换至 WSL 环境模式运行。 #### 配置 launch.json 文件以简化调试过程 对于希望利用内置调试特性的用户来说,合理定制 `.vscode/launch.json` 是必不可少的一环。下面给出了一种常见的 JSON 配置模板,适用于单步执行简单的 C++ 控制台应用程序: ```json { "version": "0.2.0", "configurations": [ { "name": "(gdb) Launch", "type": "cppdbg", "request": "launch", "program": "${workspaceFolder}/a.out", // 输出二进制路径 "args": [], "stopAtEntry": false, "cwd": "${fileDirname}", "environment": [], "externalConsole": true, "MIMode": "gdb", "setupCommands": [ { "description": "Enable pretty-printing for gdb", "text": "-enable-pretty-printing", "ignoreFailures": true } ], "preLaunchTask": "build" }, { "name": "Build and Debug Active File", "type": "cppdbg", "request": "launch", "program": "${fileDirname}/${fileBasenameNoExtension}.out", "args": [], "stopAtEntry": false, "cwd": "${fileDirname}", "environment": [], "console": "integratedTerminal", "internalConsoleOptions": "neverOpen", "miDebuggerPath": "/usr/bin/gdb", "setupCommands": [ { "description": "Enable pretty-printing for gdb", "text": "-enable-pretty-printing", "ignoreFailures": true } ], "preLaunchTask": "compile active file" } ] } ``` 这段代码定义了一个名为 `(gdb) Launch` 的调试方案,它会在每次启动时尝试加载位于 `${workspaceFolder}` 下面最新生成的目标文件 (`a.out`);另外还设定了另一个更灵活的选择——即针对单独文件即时编译加调试的功能按钮 `"Build and Debug Active File"`[^3]。 #### 自动化任务管理 tasks.json 为了让日常编码更加高效便捷,还可以进一步完善项目的自动化脚本。比如通过修改或新增 `.vscode/tasks.json` 文件中的条目,使得一键式地触发某些常用命令成为可能。这里展示的是一个典型的例子,用来指定如何处理不同类型的编译请求: ```json { "tasks": [ { "label": "build", "command": "make all", "group": { "kind": "build", "isDefault": true }, "detail": "Compile the entire project using Make.", "problemMatcher": ["$gcc"], "presentation": {"echo": true,"reveal": "always","focus": false,"panel": "shared"} }, { "label": "compile active file", "type": "shell", "command": "g++", "args": [ "-g", "${relativeFile}", "-o", "${fileDirname}/${fileBasenameNoExtension}" ], "problemMatcher": ["$gcc"], "group": { "kind": "build", "isDefault": false } } ], "version": "2.0.0" } ``` 此处展示了两个主要的任务标签:“build”负责调用 make 工具全量重建整个工程,“compile active file”则专注于仅对当前正在编辑的 .cpp/.cc 文件实施增量式的编译动作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

纬领网络

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值