VS CODE:搭建C/C++编译调试运行环境
终端中一长串的蓝字代表VS Code为我们启动了有调试器介入的程序执行(区别于在终端中仅敲入目标程序路径的直接执行)。在这里输入内容跟正常执行时是一样的。程序正常结束后,情况跟之前一样。
这一串动作的主要目的是让VS Code自动创建好tasks.json和launch.json文件,只要这两个文件内容正确,以后的调试工作就可以直接进行而无需再额外配置。由于第一次调试结束后launch.json文件是自动打开的,我们先来看一下它的内容。
launch.json
{
// 使用 IntelliSense 了解相关属性。
// 悬停以查看现有属性的描述。
// 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "gcc.exe - 生成和调试活动文件", // 该调试任务的名字,启动调试时会在待选列表中显示
"type": "cppdbg",
"request": "launch",
"program": "${fileDirname}\\${fileBasenameNoExtension}.exe",
"args": [],
"stopAtEntry": false, // 这一项控制是否在入口处暂停,默认false不暂停,改为true暂停
"cwd": "${workspaceFolder}",
"environment": [],
"externalConsole": false, // 这一项控制是否启动外部控制台(独立的黑框)运行程序,默认false表示在集成终端中运行
"MIMode": "gdb",
"miDebuggerPath": "C:\\mingw64\\bin\\gdb.exe", // 调试器路径,必须与你自己的电脑相符
"setupCommands": [
{
"description": "为 gdb 启用整齐打印",
"text": "-enable-pretty-printing",
"ignoreFailures": true
}
],
"preLaunchTask": "C/C++: gcc.exe build active file" // 调试前的预执行任务,这里的值是tasks.json文件中对应的编译任务,也就是调试前需要先编译
}
]
}
然后我们也打开tasks.json来看一看。这个文件也可以通过追远·J:基于 VS Code + MinGW-w64 的C语言/C++简单环境配置,专致小白一文中的“配置生成任务”来创建,内容基本一致
{
"tasks": [
{
"type": "shell",
"label": "C/C++: gcc.exe build active file", // 编译任务的名称,跟上面preLaunchTask的值对应
"command": "C:/mingw64/bin/gcc.exe", // 编译器的路径,须跟你自己的电脑相符
"args": [ // 编译器执行时的参数,跟手动编译时输入的内容基本一致,主要是多了-g参数,以加入调试信息
"-g",
"${file}",
"-o",
"${fileDirname}\\${fileBasenameNoExtension}.exe"
],
"options": {
"cwd": "C:/mingw64/bin"
},
"problemMatcher": [
"$gcc"
],
"group": {
"kind": "build",
"isDefault": true
}
}
],
"version": "2.0.0"
}
tasks.json和launch.json文件创建好后,在这个打开的文件夹下所有“单文件的代码”就都可以直接顺利的调试了。由于上面的代码涉及到循环输入和输出稍显复杂,这里以一个简单点的代码来演示“单步调试”。
VS CODE:搭建C/C++编译调试运行环境
1. 背景
平常都是使用Visual Studio来编译、调试和运行C/C++程序,感觉其编译调试运行环境还是不错的,但就是体量过大,每次启动都要花较长时间。源程序才几十行,VS项目的大小就几十M,而且新建项目比较费时。故现在尝试使用Visual Studio Code来搭建C/C++编译调试运行环境,以方便对小型的C/C++程序进行编程。
2. 搭建步骤
2.1 下载安装VS CODE和MINGW-W64。
VS Code官方下载(https://code.visualstudio.com/Download)
mingw-w64官方下载(https://sourceforge.net/projects/mingw-w64/files/mingw-w64/)
提示:
1. MinGW-W64-install.exe是安装程序,下载后直接点击安装即可,不过要求你的网络要好,不然下不了。
2. i686 的是32位版,x86_64 的是64位版;posix和win32是os接口类型;sjlj, seh, dwarf 是异常处理方案。只要选对操作系统版本即可,其它的对于初学者来说区别不大。下载后直接解压复制你想安装的位置即可,注意路径不能有空格或中文。
3. MinGW-W64需要配置环境。我的电脑>右键选择属性>点击高级系统设置>点击环境变量>点击系统变量path>添加MinGW-W64的bin地址(C:\mingw64\bin;)。记得点击确定保存设置,使用“gcc -v”测试MinGW-W64已装好
2.2 安装VS CODE插件。
插件 | 用途 |
---|---|
C/C++ | 搭建C/C++环境必需 |
C++ Intellisense | 智能提示插件支持部分的语法高亮,可选 |
Chinese (Simplified) Language Pack for Visual Studio Code | vs code汉化插件,可选 |
Code Runner | 运行程序的快捷键插件,可选 |
Path Autocomplete | 路径自动提示插件,可选 |
3. 代码调试
-
打开文件夹,新建1.cpp。
#include <iostream> int main(){ int a = 9; std::cout << a << std::endl; std::cout << "hello" << std::endl; std::cout << "你好" << std::endl; return 0;}
- 打开1.cpp,点击“调试”>“启动调试”。选择“C++(GDB/LLDB)”,选择“g++.exe build and debug active file”,如此可以自动创建launch.json。
{ // 使用 IntelliSense 了解相关属性。 // 悬停以查看现有属性的描述。 // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387 "version": "0.2.0", "configurations": [ { "name": "g++.exe build and debug active file", "type": "cppdbg", "request": "launch", "program": "${fileDirname}\\${fileBasenameNoExtension}.exe", "args": [], "stopAtEntry": false, "cwd": "${workspaceFolder}", "environment": [], "externalConsole": false, "MIMode": "gdb", "miDebuggerPath": "C:\\mingw64\\bin\\gdb.exe", "setupCommands": [ { "description": "为 gdb 启用整齐打印", "text": "-enable-pretty-printing", "ignoreFailures": true } ], "preLaunchTask": "g++.exe build active file" } ]}
- 打开1.cpp,点击“调试”>“启动调试”(不要在launch.json上进行调试)。此时系统报错,点击“配置任务” ,选择“g++.exe build active file”。如此系统会自动创建tasks.json。
若“g++.exe build active file”不存在,可能是因为你在launch.json进行调试,转换到1.cpp重新调试即可。
{// 有关 tasks.json 格式的文档,请参见 // https://go.microsoft.com/fwlink/?LinkId=733558 "version": "2.0.0", "tasks": [ { "type": "shell", "label": "g++.exe build active file", "command": "C:\\mingw64\\bin\\g++.exe", "args": [ "-g", "${file}", "-o", "${fileDirname}\\${fileBasenameNoExtension}.exe" ], "options": { "cwd": "C:\\mingw64\\bin" }, "problemMatcher": [ "$gcc" ], "group": "build" } ]}
- 最后打开1.cpp,点击“调试”>“启动调试”即可调试运行。
4. 代码运行(3种方法)
4.1 以非调试模式运行(CTRL + F5)
注意:其编码方式是UTF-8。若换成GB2312,可能无法输出中文。
4.2 终端G++命令运行
g++ 1.cpp -o 1.exe; ./1.exe
注意:其编码方式是GB2312。若换成UTF-8,输出结果中的中文会乱码。
4.3 安装CODE RUNNER插件,按运行键(图中红色矩形)运行
注意:其编码方式是GB2312。若换成UTF-8,输出结果中的中文会乱码。
5. 总结
- 熟悉VS Code不可能一蹴而就,搭建环境时只需把基本环境搭建好,能够编译调试运行C/C++程序即可,不需一下添加过多功能或安装许多插件。VS Code用多后有需求,自然而然就知道怎么配置环境,像快捷键之类都不怎么需要记,用多了自然就知道了。
- 网上有许多c_cpp_properties.json、tasks.json、launch.json,重点是看懂再用。对于新手而言,系统自动生动的tasks.json和launch.json已基本够用。
- 对于VS Code中文乱码有疑惑,可以参考VS Code:4个中文乱码问题及解决方法。