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变量中
PATH变量

最后在命令行输入

gcc --version
g++ --version

输出显示这样子,咱们的编译环境就成功搭上啦
命令行gcc测试

三、配置环境

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}:系统中的环境变量

posted @ 2021-11-23 18:51  yuezi2048  阅读(35)  评论(0编辑  收藏  举报