VSCode 配置C++開發環境

来源:https://www.cnblogs.com/seafever/archive/2020/03/26/12571272.html
-Advertisement-
Play Games

目錄 1. "安裝VSCode應用程式" 2. "安裝相關插件" 1. "漢化插件" 2. "C++編輯器插件" 3. "編寫配置文件" 1. "tasks.json" 2. "launch.json" 3. "c_cpp_properties.json" 第一步、安裝VSCode應用程式 打開 " ...


目錄

  1. 安裝VSCode應用程式
  2. 安裝相關插件
    1. 漢化插件
    2. C++編輯器插件
  3. 編寫配置文件
    1. tasks.json
    2. launch.json
    3. c_cpp_properties.json

第一步、安裝VSCode應用程式

  打開VSCode官網,下載對應安裝包並預設安裝(這裡指明:安裝路徑可以修改)
VSCode官網

第二步、安裝相關插件

  此時的VSCode僅僅是一個英文文本編輯器,還稱不上開發工具,所以需要相關的插件支持。
  需要說明的是:這裡我選擇我的母語作為編輯器的語言,所以會多安裝一個漢化插件!

安裝 漢化插件

  打開VSCode,在插件搜索輸入框輸入“Chinese”,搜索插件“Chinese (Simplified) Language Pack for Visual Studio Code”。點擊install安裝插件。
安裝漢化插件

安裝 C++編輯器插件

  在插件搜索輸入框輸入“C++”,搜索插件“C/C++ for Visual Studio Code”。點擊install安裝插件。

第三步、編寫配置文件

  此時只是勉強算得上一個開發工具,不過還需要進一步配置!
  前提說明:這裡預設已經安裝並配置好了C++相關的編譯環境!如果有需要請看附錄--C/C++編譯環境配置
  在你寫代碼的地方新建一個文件夾,並命名為“.vscode”。然後再在“.vscode”文件夾下新建三個文件,分別為:
    1. tasks.json
    2. launch.json
    3. c_cpp_properties.json

參考:
參考圖

編寫 tasks.json 文件

  該文件文件來告訴VS Code如何構建(編譯)程式。

{
    "version": "2.0.0",
    "command": "g++",
    "args": [
        "-g",
        "${file}",
        "-o",
        "${fileBasenameNoExtension}.exe"
    ], // 編譯命令參數
    "problemMatcher": {
        "owner": "cpp",
        "fileLocation": [
            "relative",
            "${workspaceFolder}"
        ],
        "pattern": {
            "regexp": "^(.*):(\\d+):(\\d+):\\s+(warning|error):\\s+(.*)$",
            "file": 1,
            "line": 2,
            "column": 3,
            "severity": 4,
            "message": 5
        }
    },
    "presentation": {
        "echo": true,
        "reveal": "always",
        "focus": false,
        "panel": "new", //這裡shared表示共用,改成new之後每個進程創建新的埠
        "showReuseMessage": true,
        "clear": false
    }
}

編輯 launch.json 文件

  該文件負責配置VS Code。

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) Launch", // 配置名稱,將會在啟動配置的下拉菜單中顯示
            "type": "cppdbg", // 配置類型,這裡只能為cppdbg
            "request": "launch", // 請求配置類型,可以為launch(啟動)或attach(附加)
            "program": "${workspaceFolder}/${fileBasenameNoExtension}.exe", // 將要進行調試的程式的路徑
            "args": [], // 程式調試時傳遞給程式的命令行參數,一般設為空即可
            "stopAtEntry": false, // 設為true時程式將暫停在程式入口處,一般設置為false
            "cwd": "${workspaceFolder}", // 調試程式時的工作目錄,一般為${workspaceRoot}即代碼所在目錄 workspaceRoot已被棄用,現改為workspaceFolder
            "environment": [],
            "externalConsole": true, // 調試時是否顯示控制台視窗,一般設置為true顯示控制台
            "MIMode": "gdb",
            "miDebuggerPath": "E:\\MinGW\\bin\\gdb.exe", // miDebugger的路徑,註意這裡要與MinGw的路徑對應
            "preLaunchTask": "g++", // 調試會話開始前執行的任務,一般為編譯程式,c++為g++, c為gcc
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": false
                }
            ]
        }
    ]
}

編輯 c_cpp_properties.json 文件

  該文件用於進一步控制C / C ++擴展。它將允許您更改設置,例如編譯器的路徑,包含路徑,C ++標準(預設為C ++ 17)等。
  需要說明:這個文件是非必須的,可以沒有!

{
    "configurations": [
        {
            "name": "Win32",
            "includePath": ["${workspaceFolder}/**"],
            "defines": ["_DEBUG", "UNICODE", "_UNICODE"],
            "compilerPath": "E:\\MinGW\\bin\\gcc.exe",
            "cStandard": "c11",
            "cppStandard": "c++17",
            "intelliSenseMode": "clang-x86"
        }
    ],
    "version": 4
}

附註:配置好了記得重啟!重啟可以解決 99% 的問題!
另外需要註意的是:代碼別寫錯!

附錄

c_cpp_properties.json 文件中 includePath 路徑的獲取

打開CMD命令行工具,輸入gcc -v -E -x c++ -
獲取信息
參考圖片

需要說明:在 includePath 的第一行配置的是 MinGW根目錄下的 include文件夾。

C / C ++編譯環境配置

  1.去MinGW官網下載安裝程式,預設安裝即可。
  需要說明:可修改安裝路徑。
  2.安裝完成後啟動程式並安裝基礎庫文件。
參考:
安裝相關庫

  3.在系統(或用戶)環境變數 Path 中添加 MinGW 安裝根目錄下的 bin 文件夾路徑,例如:E:\MinGW\bin
  4.在CMD命令行工具中輸入 gcc -v 查看是否安裝成功。
配置成功樣圖

settings.json 簡單配置

{
    "files.associations": {
        "ostream": "cpp"
    },
    // PowerShell
    "terminal.integrated.shell.windows": "C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\powershell.exe"  
}

一鍵生成 tasks.json、launch.json、c_cpp_properties.json 和 setting.json 等配置文件

  值得說明:這裡雖然可以一鍵生成,但還是需要修改!

  1. 編寫一個簡單的c++源文件,這裡以HelloWorld.cpp為例;
    HelloWorld.cpp
  2. 按下 F5 運行程式(或Ctrl + F5,根據實際情況而定);
  3. 選擇 "C++ (GDB\LLDB)";
    C++ (GDB\LLDB)
  4. 按照需求自行選擇即可。

參考文章

Visual Studio Code中的C ++和Mingw-w64入門

版權聲明

原文作者:Seaver(海之戀SF)
如要轉載,請務必註明出處!
原文地址:https://www.cnblogs.com/seafever/p/12571272.htmle


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 按照國際慣例先放效果圖 index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale ...
  • 在 HTML 文檔中,標題很重要;HTML 標題可以用來呈現文檔結構,設置得當的標題有利於用戶瀏覽您的網頁。標題(Heading)是通過 <h1> - <h6> 標簽進行定義的.<h1>定義最大的標題,<h6> 定義最小的標題。 註釋: A.瀏覽器會自動地在標題的前後添加空行。B.預設情況下,HTM ...
  • HTML 屬性:屬性是為 HTML 元素提供的附加信息。 HTML 元素可以設置屬性 屬性可以在元素中添加附加信息 屬性一般描述於開始標簽 屬性總是以名稱/值對的形式出現,比如:name="value"。 e.g:<a href=https://www.cnblogs.com/dhnblog/">這 ...
  • 圖解Java設計模式之外觀模式 影院管理項目 傳統方式解決影院管理 傳統方式解決影院管理問題分析 外觀模式基本介紹 外觀模式原理類圖 外觀模式解決影院管理 外觀模式的註意事項和細節 影院管理項目 組建一個家庭影院 :DVD 播放器、投影儀、自動屏幕、環繞立體聲、爆米花機,要求完成使用家庭影院的功能, ...
  • 問題引入:電腦里安裝了從官網下載的python3.8.0,。先使用了菜鳥教程的方法2安裝。https://www.runoob.com/numpy/numpy-install.html 發現產生錯誤。先是提示我的pip工具沒有更新到最新版本,於是根據提示更新後,發現仍有錯誤,於是放棄使用這方法里的命 ...
  • 需求 基於Spring, SpringMVC, Mybatis 實現一個類似京東商城的3C電子商城系統, 能夠實現商品管理與展示, 加入購物車, 支付購買等功能 運行環境 jdk1.8,tomcat8.5,mysql5.6,EclispseEE 項目技術 spring springmvc, myba ...
  • 框架:具有很強的通用性,且封裝了一些通用實現方法的項目模板 (非同步框架): 高性能的網路請求 高性能的數據解析 高性能的持久化存儲 高性能的全站數據爬取 高性能的深度爬取 高性能的分散式 Scrapy環境安裝 IOS和Linux windows 安裝完成後,輸入 測試一下,出現如下圖顯示,即安裝成功 ...
  • 一、ItemPipeLine 1.爬蟲提取出的數據存入item之後,item中保存的數據需要進一步處理,比如:清洗,去重,存儲等 2.pipeline需要process_item函數 (1)process_item​:spider提出來的item作為參數出入,同時傳入的還有spider;此方法是必須 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...