VS Code编译C/C++

C/C++环境的配置要比python的复杂许多,好几个配置文件要写。
一、编译C/C++的环境一般都是集成在我们的编辑器中的,如果电脑上有codeblock和dev c++的读者可以去安装路径下找找MinGW文件夹,可以不用重复下载。而没有的读者则需要下载MinGW
这里写图片描述
二、配置环境变量,这里就不重复截图了,下面的是python配置环境变量的步骤,而这里只要找到我们的MinGW文件夹下的bin目录(我的是D:\MinGW\mingw64\bin),将其添加进去即可。
这里写图片描述
三、打开VS Code,添加两个插件,记得都要重新加载或者重启VS Code一次
这里写图片描述
四、打开自己的项目,这里以Hello World为例。

#include <iostream>
using namespace std;
int main() {cout << "Hello World";return 0;
}

打开之后我们发现,头文件出现了绿色的波浪线,这配置C/C++也是常见的问题之一,这是由于找不到头文件导致的
这里写图片描述
我们点击边上的橙色小灯泡,选择“Edit ‘includePath’ setting”,之后会创建一个文件夹.vscode(这个文件夹存放了配置文件),文件夹中有c_cpp_properties.json这个文件。
这个文件是json的格式,其中configurations参数下有三个元素,分别是Mac、Linux、Win32,我们根据自己的情况修改相应的配置文件。下面以Win32为例,找到相应includePath参数。

{"name": "Win32","includePath": ["${workspaceFolder}"],"defines": ["_DEBUG","UNICODE","_UNICODE"],"intelliSenseMode": "msvc-x64","browse": {"path": ["${workspaceFolder}"],"limitSymbolsToIncludedHeaders": true,"databaseFilename": ""},"cStandard": "c11","cppStandard": "c++17"}

要添加的内容需要我们打开我们的cmd,执行**gcc -v -E -u c++ -**这个命令,找到调用g++我们需要用到的文件路径,内容很多,我们找到最下面的路径部分。
这里写图片描述
将这些参数添加到includePath后面,中间用逗号隔开,修改之后如下。细心的读者会发现上面只有3条记录,为什么下面的参数我写了5条,这是因为当你添加完cmd中输出的内容之后,保存配置文件,查看自己的C++文件时,绿色波浪线仍然没有消失,这里我们可以再次点击小灯泡,VS Code会继续补全我们的路径。之后绿色波浪线消失,说明我们编译路径已经配置完成。

{"name": "Win32","includePath": ["${workspaceFolder}","D:/MinGW/mingw64/bin/../lib/gcc/x86_64-w64-mingw32/7.3.0/include","D:/MinGW/mingw64/bin/../lib/gcc/x86_64-w64-mingw32/7.3.0/include-fixed","D:/MinGW/mingw64/bin/../lib/gcc/x86_64-w64-mingw32/7.3.0/../../../../x86_64-w64-mingw32/include","D:/MinGW/mingw64/lib/gcc/x86_64-w64-mingw32/7.3.0/include/c++","D:/MinGW/mingw64/lib/gcc/x86_64-w64-mingw32/7.3.0/include/c++/x86_64-w64-mingw32"],"defines": ["_DEBUG","UNICODE","_UNICODE"],"intelliSenseMode": "msvc-x64","browse": {"path": ["${workspaceFolder}"],"limitSymbolsToIncludedHeaders": true,"databaseFilename": ""},"cStandard": "c11","cppStandard": "c++17"}

五、打开C++文件,我们按F5或者找到调试执行,之后将显示我们没有launch.json文件,VS Code会继续为我们创建一个文件,我们可以将launch.json文件的内容删除,并下面的代码完全复制进去。注意:复制进去之后要修改miDebuggerPath参数,这里面填写自己的gdb.exe路径,至此我们的编译配置已完成。

{"version": "0.2.0","configurations": [{"name": "C++ Launch (GDB)",                 "type": "cppdbg",                           "request": "launch",                        "targetArchitecture": "x86",                "program": "${file}.exe",                   "miDebuggerPath":"D:\\MinGW\\mingw64\\bin\\gdb.exe", "args": [],     "stopAtEntry": false,                       "cwd": "${workspaceRoot}",                  "externalConsole": true,                    "preLaunchTask": "g++"                    }]
}

六、Ctrl+Shift+P,输入Tasks:Configure Task,之后选择使用模板创建tesks.json文件
这里写图片描述
同样覆盖源文件,填入下面的内容,用来配置编译命令

{// See https://go.microsoft.com/fwlink/?LinkId=733558// for the documentation about the tasks.json format"version": "2.0.0","command": "g++","args": ["-g","${file}","-o","${file}.exe"],    // 编译命令"problemMatcher": {"owner": "cpp","fileLocation": ["relative", "${workspaceRoot}"],"pattern": {"regexp": "^(.*):(\\d+):(\\d+):\\s+(warning|error):\\s+(.*)$","file": 1,"line": 2,"column": 3,"severity": 4,"message": 5}}
}

七,按F5即可执行,但是这里有一个小问题本人还没有解决,就是console控制台只闪出来一下,不能观察到结果,我目前的解决办法是在return 0之前增加一句system("pause"),缺点在于每个文件都要写,不知道有没有更好的办法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/569630.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

H5的Video事件,控制方法,及监听

1.标签基本属性 src &#xff1a;视频的属性 poster&#xff1a;视频封面&#xff0c;没有播放时显示的图片preload&#xff1a;预加载autoplay&#xff1a;自动播放loop&#xff1a;循环播放controls&#xff1a;浏览器自带的控制条width&#xff1a;视频宽度 height&#xff…

Hexo+GitHub 快速搭建个人博客(一)---- 基本部署

前期准备&#xff1a; 1.Git shell 2.node.js 3.在github上创建一个仓库&#xff0c;仓库命名格式为xxx.github.io 一、安装Hexo cd进入自己想要安装的目录下&#xff0c;执行下面的命令 npm install hexo-cli -g 升级Hexo npm update hexo -g 卸载Hexo 如果安装过程中…

Gym - 101755G Underpalindromity (树状数组)

Let us call underpalindromity of array b of length k the minimal number of times one need to increment some elements bj by 1 so that the array b would become a palindrome, that is, b1  bk, b2  bk - 1, and so on. The array of length n, consisting of i…

Hexo+GitHub 快速搭建个人博客(二)---- 域名解析

前期准备&#xff1a; 备案的国内域名或者国外域名 &#xff08;后面会解释为什么&#xff0c;这里以阿里云域名为例&#xff09; 一、将个人域名与GitHub博客绑定 我们在Hexo目录下的source子目录内创建一个txt文件&#xff0c;内容写自己的域名&#xff0c;这里可以是一级…

.net core consul 服务配置 服务发现 服务健康检测 服务变更加载

准备环境 安装consul之后 1. 创建一个.net core webapi 举例为UsercenterService 2. nuget引用Consul组件 https://github.com/PlayFab/consuldotnet 3. 创建配置实体类 &#xff08;后面涉及功能介绍时候再解释属性含义&#xff09; 1 public class AppSettings2 {3 …

Hexo+GitHub 快速搭建个人博客(三)---- 改变主题

前期准备&#xff1a; 基本的Linux命令 基本的GitHub命令 Hexo有多种博客框架&#xff0c;在 https://hexo.io/themes/ 里可以找到非常多优秀的博客框架&#xff0c;而且都是免费的。 首先大家可以去找一款自己喜欢的框架&#xff0c;可以选择浏览和直接进入GitHub进行fork …

hdu1814 Peaceful Commission

题目链接&#xff1a;戳我 菜得不行了&#xff0c;直到今天才刚开始学2-SAT。。。。 2-SAT的模板&#xff0c;因为是求最小字典序&#xff0c;所以只能用上限为\(O(nm)\)的最暴力的方法来做。。。 #include<iostream> #include<cstring> #include<cstdio> #i…

Vue入门 ---- 组件式开发

##组件 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><meta http-equiv"X-UA-Compatible" conten…

/usr/bin/python^M: 解释器错误: 没有那个文件或目录

【1】问题现象 执行python脚本&#xff0c;提示错误&#xff1a;/usr/bin/python^M: 解释器错误: 没有那个文件或目录 【2】原因分析 大多数是因为脚本文件在windows下编辑过。在windows下&#xff0c;每一行的结尾是\r\n&#xff0c;而在linux下文件的结尾是\n。 那么&#xf…

Vue入门 ---- 组件通信

##组件通信&#xff1a; 子组件获取父组件的数据父组件获取子组件的数据平行组件之间的通信vue2.0中用子组件修改父组件数据报错问题一定需要通过子组件修改父组件 子组件获取父组件的数据 通过子组件中的属性props&#xff0c;以与父组件数据的绑定。&#xff08;注意&#x…

[51nod1201]整数划分

题目链接&#xff1a; 51nod1201 神仙DP 设\(f[i][j]\)表示\(i\)分成\(j\)个数的划分数&#xff0c;如何转移&#xff1f; 有转移式&#xff1a;\(f[i][j]f[i-j][j-1]f[i-j][j]\) 为什么呢&#xff1f;第一种是先加一个划分出来的数\(1\)&#xff0c;但是为了和之前的所有数不一…

Vue入门 ---- vue-loader 、vue-cli

简介&#xff1a; vue-loader&#xff0c;来源于css-rouder、url-loader、html-loader… 后台node.js–>require exports等都是基于模块的开发 broserify 较早的模块加载器&#xff0c;但是只能加载js webpack&#xff0c;模块加载器&#xff0c;一切东西皆模块&#xff0c;…

Python档案袋( 命令行操作 及 Os与Shutil文件操作补充 )

调用系统命令 import os#调用系统命令&#xff0c;输出只能输出到屏幕上&#xff0c;不能用变量接收 os.system("ipconfig")#调用系统命令&#xff0c;并把执行结果存到变量中 resos.popen("ipconfig").read() print(res) OS模块文件操作 简单的文件和目录…

Vue入门---- vue-router

#简介&#xff1a; vue-router官网 用 Vue.js vue-router 可以快速创建SPA&#xff08;单页应用程序&#xff09;&#xff0c;是非常简单的。使用 Vue.js &#xff0c;我们已经可以通过组合Component来组成应用程序。 引入 vue-router 的过程&#xff1a;将组件(components)映…

Vue入门 ---- vuex

##简介 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态&#xff0c;并以相应的规则保证状态以一种可预测的方式发生变化。 vuex分为三大部分&#xff1a; state&#xff0c;驱动应用的数据源&#xff1b; view&#xff0c;以声…

2 Class类

在程序运行期间&#xff0c;Java运行时系统始终为所有的对象维护一个被称为运行时地类型标识。这个信息跟踪着每个对象所属地类。虚拟机 利用运行时类型信息选择相应地方法执行。 然而&#xff0c;可以通过专门地Java类访问这些信息。保存这些信息地类称为Class。这个名字很容易…

Dijkstra算法(c++版)

最短路径&#xff08;DP的应用&#xff09; 单源最短路径&#xff0c;不允许出现负环 核心思想&#xff1a;更新估算距离&#xff0c;松弛 δ(u,v)≤δ(u,x)δ(x,v)\delta(u, v) \leq \delta(u, x) \delta(x, v) δ(u,v)≤δ(u,x)δ(x,v) 时间复杂度与采用的数据结构有关&…

day1-参数化关联函数响应断言

1、参数化 1&#xff09;、准备参数化文件 2&#xff09;&#xff0c;添加CSV数据文件设置 3&#xff09;、在请求里 引用参数 2、关联函数 1&#xff09;、给学生充值金币需要从登录返回获取登录cookie 在登录接口添加后置处理器JSON Extractor 用户登录返回结果为&#xff1…

MySQL 8.0 error 2059: Authentication plugin 'caching_sha2_password' cannot be loaded

安装MYSQL8.0版本之后&#xff0c;使用可视化管理工具Workbench或者Navicat都会产生一个类似的报错。 原因&#xff1a;MYSQL8.0之前的版本中加密规则为mysql_native_password. 而mysql8之后的加密规则为caching_sha2_password. 解决办法&#xff1a; 打开CMD进入MYSQL&#…

语句覆盖,判定覆盖,条件覆盖,条件/判定覆盖,条件组合覆盖,路径覆盖

最近在复习软件测试的考试&#xff0c;每次到白盒测试这里都要为这几种逻辑覆盖方法感到头疼&#xff0c;这次终于决定好好整理出来。 逻辑覆盖是通过对程序逻辑结构的遍历实现程序的覆盖。它是一系列测试过程的总称&#xff0c;这组测试过程逐渐进行越来越完整的通路测试。 根…