2021-11-23 利用VSCode搭建C/C++环境
工欲善其事,必先利其器
—— 利用VSCode搭建C/C++环境
## 一、软件下载
tips:这边下载完,安装的时候建议把选项全勾上
前面两个勾选以后咱们打开软件就可以愉快的用通过右键菜单打开VSCode了,挺方便的嘻嘻(●'◡'●)*
至于添加到PATH,在命令行直接输入code就可打开伟大的编译软件VS了
code
这才是一个程序员该有的操作嘛有木有~~
二、安装需要的编译套装
之前在Ubuntu,只要命令行敲几句代码就可以了
sudo apt update
sudo apt install build-essential
战场一转移到了Windows系统,就麻烦了点,不过问题不大,就需要自己手动下载MinGW
这是我用的安装包:
MinGW安装包下载链接
提取码: vp5j
注意第二项选择x86_64(大家一般都是这个系统把,32位的得另外去官网下)
后面选好路径直接安装,等就ws了,非常适合我这样的大懒人
注意:配置的路径要记得,后面在VSCode配置的时候要用到
win+S 搜索环境变量,将WinGW下的bin目录放到path变量中
最后在命令行输入
gcc --version
g++ --version
输出显示这样子,咱们的编译环境就成功搭上啦
三、配置环境
1.解决一些非常令人难受的问题
界面全英文非常难受
刚进去的小伙伴们会发现,界面全是英文的,非~~常难受
其实我们在插件中搜索Language安装一个中文插件即可解决问题
界面是黑色的非常难受
VScode默认是黑色的主题,其实是有其他主题的,甚至于你可以搜索拓展category:themes获取更多主题
操作方法,首先在主界面按下Ctrl+shift+p 进入控制台,输入Color Theme回车就可以选择你想要的主题
2.安装C/C++扩展
其实刚进去,右下角会有提示询问你是否安装C/C++扩展的,直接安装就行了,当然也可自行搜索C/C++扩展进行安装,
3.搭建C/C++环境
配置编译器
接下来配置编译器路径,按快捷键Ctrl+Shift+P调出命令面板,输入C/C++,选择“Edit Configurations(UI)”进入配置
这里有两个配置
C:\ljy\MingGW\mingw64\bin\g++.exe
C:\ljy\MingGW\mingw64\bin\gcc.exe
IntelliSense 模式选择:gcc-x64
这时候.vscode有一个c_cpp_properties.json文件就说明设置生效了
后续写完程序 用快捷键 Ctrl + ~ 就可以打开终端运行了
1.配置构建任务
接下来,创建一个tasks.json文件来告诉VS Code如何构建(编译)程序。该任务将调用g++编译器基于源代码创建可执行文件。 按快捷键Ctrl+Shift+P调出命令面板,输入tasks,选择“Tasks:Configure Default Build Task”:
再选择“C/C++: g++.exe build active file”:
我的task.json配置参考如下
{
"version": "2.0.0",
"tasks": [
{
"type": "shell",
"label": "C/C++: g++.exe 生成活动文件",//任务的名字,就是刚才在命令面板中选择的时候所看到的,可以自己设置
"command": "C:/ljy/MingGW/mingw64/bin/g++.exe", // //这里就输入minGW bin目录下g++.exe 路径
"args": [ //编译时候的参数
"-g", //添加gdb调试选项
"${file}",
"-o", //指定生成可执行文件的名称
"${workspaceFolder}\\.exe\\${fileBasenameNoExtension}.exe",
"-std=c++11" //编译标准c++11
],
"options": {
"cwd": "C:\\ljy\\MingGW\\mingw64\\bin" //这里就输入minGW bin目录的绝对路径
},
"problemMatcher": [
"$gcc"
],
"group":{
"kind": "build",
"isDefault": true //表示快捷键Ctrl+Shift+B可以运行该任务
}
}
]
}
2.配置调试设置
vscode提供了调试的功能,快捷键是F5,但是调试的配置需要我们配置一下。具体配置文件是在.vscode文件夹下的launch.json文件
环境配置是一大难关,各位读者可以根据内容调整具体的数值
我的launch.json配置参考
{
"version": "0.2.0",
"configurations": [{
"name": "cpp.exe - 生成和调试活动文件", // 配置名称,将会在启动配置的下拉菜单中显示
"type": "cppdbg", // 配置类型,对于C/C++可认为此处只能是cppdbg,由cpptools提供;不同编程语言不同
"request": "launch", // 可以为launch(启动)或attach(附加)
"program": "C:\\Windows\\System32\\cmd", // 将要进行调试的程序的路径
"args": [
"/C",
"${workspaceFolder}\\.exe\\${fileBasenameNoExtension}.exe",
"&",
"pause"
], // 程序调试时传递给程序的命令行参数,一般设为空
"stopAtEntry": false, // 设为true时程序将暂停在程序入口处,相当于在main上打断点
"cwd": "${workspaceFolder}", // 调试程序时的工作目录,此为工作区文件夹;改成${fileDirname}可变为文件所在目录
"environment": [], // 环境变量
"externalConsole": true, // 使用单独的cmd窗口,与其它IDE一致;为false时使用内置终端
"internalConsoleOptions": "neverOpen", // 如果不设为neverOpen,调试时会跳到“调试控制台”选项卡,你应该不需要对gdb手动输命令吧?
"MIMode": "gdb", // 指定连接的调试器,可以为gdb或lldb。但我没试过lldb
"miDebuggerPath": "C:/ljy/MingGW/mingw64/bin/gdb.exe", // 调试器路径,Windows下后缀不能省略,Linux下则不要
"setupCommands": [
{ // 模板自带,好像可以更好地显示STL容器的内容,具体作用自行Google
"description": "为 gdb 启用整齐打印",
"text": "-enable-pretty-printing",
"ignoreFailures": false
}
],
"preLaunchTask": "C/C++: g++.exe 生成活动文件" // 调试前执行的任务,一般为编译程序。与tasks.json的label相对应
}]
}
3.配置其他的设置
setting.json可以参考这位作者:https://zhuanlan.zhihu.com/p/345521588
最后是一些胡扯的费话(友情提示)
1.大家复制的时候也不要全复制,路径要注意是否对应正确
2.我使用cmd作为调试的程序,将exe文件作为args参数运行task.json中所生成的exe文件,另外加了pause参数解决了exe文件运行完闪退的问题
3.preLaunchTask的值要对应task.json中label的名字
4.请读者注意,因为本人看不惯目录有很多exe文件,所以这边我在task.json中 -O 后面的值是如下方所示,即所有exe文件我全放在了工作文件夹的.exe文件夹中,请注意一下后续路径问题
"${workspaceFolder}\\.exe\\${fileBasenameNoExtension}.exe",
5.一定要注意,路径不要用一个反斜杠链接,会出错,要么用两个反斜杠,要么用一个斜杠'/'
附录:
整理了VsCode一些已经定义好的变量供大家参考
${workspaceFolder} :表示当前workspace文件夹路径,也即/home/Coding/Test
${workspaceRootFolderName}:表示workspace的文件夹名,也即Test
${file}:文件自身的绝对路径,也即/home/Coding/Test/.vscode/tasks.json
${relativeFile}:文件在workspace中的路径,也即.vscode/tasks.json
${fileBasenameNoExtension}:当前文件的文件名,不带后缀,也即tasks
${fileBasename}:当前文件的文件名,tasks.json
${fileDirname}:文件所在的文件夹路径,也即/home/Coding/Test/.vscode
${fileExtname}:当前文件的后缀,也即.json
${lineNumber}:当前文件光标所在的行号
${env:PATH}:系统中的环境变量