Ubuntu16.04下配置VScode的C/C++開發(fā)環(huán)境
1. Vscode安裝
Visual studio code是微軟發(fā)布的一個(gè)運(yùn)行于 Mac OS X、Windows和 Linux 之上的,針對(duì)于編寫現(xiàn)代 Web 和云應(yīng)用的跨平臺(tái)源代碼編輯器。第一種方式是從VScode官網(wǎng)下載.deb文件,然后雙擊該文件會(huì)打開軟件中心進(jìn)行安裝。

另一種方式是通過Terminal進(jìn)行安裝,首先輸入下面三條語(yǔ)句安裝umake:
sudo add-apt-repository ppa:ubuntu-desktop/ubuntu-make sudo apt-get update sudo apt-get install ubuntu-make
然后通過umake來安裝VScode:
umake web visual-studio-code
安裝完畢后即可打開VScode,主界面如下:

2. Vscode環(huán)境配置
(1)安裝c/c++插件
首先通過左邊欄的Extension欄目安裝C++插件,操作如下圖:

(2)建立工程
由于VScode是以文件夾的形式管理工程的,因此我們首先新建一個(gè)文件夾,我這里取名叫hello。
然后通過VScode打開此文件夾:
新建main.cpp文件并輸入程序:

(3)更改配置文件(launch.json)
點(diǎn)擊左側(cè)的Debug按鈕,選擇添加配置(Add configuration),然后選擇C++(GDB/LLDB),將自動(dòng)生成launch.json文件,具體操作如下:
生成的默認(rèn)json文件如下:
// Use IntelliSense to learn about possible attributes.
// Hover to view descriptions of existing attributes.
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "(gdb) Launch",
"type": "cppdbg",
"request": "launch",
"program": "enter program name, for example ${workspaceFolder}/a.out",
"args": [],
"stopAtEntry": false,
"cwd": "${workspaceFolder}",
"environment": [],
"externalConsole": true,
"MIMode": "gdb",
"setupCommands": [
{
"description": "Enable pretty-printing for gdb",
"text": "-enable-pretty-printing",
"ignoreFailures": true
}
]
}
]
}
注意:這里需要將program項(xiàng)的內(nèi)容改為調(diào)試時(shí)運(yùn)行的程序,將其改為main.out即可。具體更改如下:
"program": "enter program name, for example ${workspaceFolder}/a.out",
改為
"program": "${workspaceFolder}/main.out",
該語(yǔ)句指的是當(dāng)前工作文件夾下的main.out文件,更改完畢的launch.json文件見附錄。
(4)添加構(gòu)建(編譯、鏈接等)任務(wù)(tasks.json)
為了方便在VScode里編譯C++代碼,我們可以將類似g++ -g main.cpp等g++命令寫入VScode的任務(wù)系統(tǒng)。首先,利用快捷鍵ctrl+shift+p打開命令行,輸入Tasks: Run task,會(huì)出現(xiàn)如下提示:
No task to run found. configure tasks...
回車,然后依次選擇如下:
Create tasks.json file from template
Others Example to run an arbitrary external command.
生成默認(rèn)的tasks.json文件如下:
{
// See https://go.microsoft.com/fwlink/?LinkId=733558
// for the documentation about the tasks.json format
"version": "2.0.0",
"tasks": [
{
"label": "echo",
"type": "shell",
"command": "echo Hello"
}
]
}
這里的label為任務(wù)名,我們將”label"= "echo"改為”label"= "build"。由于我們的指令是g++,這里將”command“=”echo Hello“改為”command“=”g++“。然后添加g++的參數(shù)args。如果我們的g++指令為:g++ -g main.cpp,這里可以把參數(shù)設(shè)置為如下:
{
"tasks": [
{
"label": "build",
"type": "shell",
"command": "g++",
"args": ["-g", "${file}"]
}
]
}
如果我們想配置g++指令為:g++ -g main.cpp -std=c++11 -o main.out,則參數(shù)可設(shè)置為:
{
"tasks": [
{
"label": "build",
"type": "shell",
"command": "g++",
"args": ["-g", "${file}", "-std=c++11", "-o", "${fileBasenameNoExtension}.out"]
}
]
}
我們可以通過舉一反三來配置不同的g++指令。完整的tasks.json文件可參考附錄。
(5)簡(jiǎn)單斷點(diǎn)調(diào)試
經(jīng)過上述配置之后就可以對(duì)我們寫的程序進(jìn)行簡(jiǎn)單的配置。在進(jìn)行下面的操作前,我們應(yīng)當(dāng)保證launch.json和tasks.json的正確性并且已經(jīng)成功保存。
使用快捷鍵ctrl+shift+p調(diào)出命令行,選擇執(zhí)行我們的build任務(wù),build成功后,點(diǎn)擊開始調(diào)試。具體操作如下:

值得注意的是,這里如果每次更改了程序需要重新build,然后再進(jìn)行調(diào)試;如果直接進(jìn)行調(diào)試則運(yùn)行的是上次build的結(jié)果。通過在launc.json作如下更改可以使得每次調(diào)試之前會(huì)自動(dòng)進(jìn)行build:
這里在launch.json文件中添加了”preLaunchTask“=”build",也就是添加一個(gè)launch之間的任務(wù),任務(wù)名為build,這個(gè)build就是我們?cè)趖asks.json中設(shè)置的任務(wù)名。
3.總結(jié)及注意事項(xiàng)
本文對(duì)Ubuntu16.04系統(tǒng)下配置基于VScode的C/C++開發(fā)環(huán)境進(jìn)行了簡(jiǎn)單的介紹,主要步驟為:
1.安裝VScode,可以通過在官網(wǎng)下載和命令行的方式進(jìn)行安裝。(順便提一下,在命令行安裝的過程中可能會(huì)讓你輸入a)
2.新建C/C++工程,VScode以文件夾為管理工程的方式,因此需要建立一個(gè)文件夾來保存工程。
3.配置launch.json文件,它是一個(gè)啟動(dòng)配置文件。需要進(jìn)行修改地方的是指定運(yùn)行的文件,其次我們還可以在里面添加build任務(wù)。
4.配置tasks.json文件,這個(gè)文件用來方便用戶自定義任務(wù),我們可以通過這個(gè)文件來添加g++/gcc或者是make命令,方便我們編譯程序。
5.上述四個(gè)流程完了之后我們就可以進(jìn)行基礎(chǔ)的C/C++開發(fā)與調(diào)試了。
4. 附錄
這里給出一個(gè)較完整的配置文件和任務(wù)文件,筆者的系統(tǒng)的Ubuntu16.04 LTS,測(cè)試時(shí)間是2018/11/14。由于版本不同可能會(huì)有所變化,因此該配置僅供參考!
(1)launch.json
{
// Use IntelliSense to learn about possible attributes.
// Hover to view descriptions of existing attributes.
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"name": "(gdb) Launch",
"type": "cppdbg",
"request": "launch",
"program": "${workspaceFolder}/${fileBasenameNoExtension}.out",
"args": [],
"stopAtEntry": false,
"cwd": "${workspaceFolder}",
"environment": [],
"externalConsole": true,
"MIMode": "gdb",
"preLaunchTask": "build",
"setupCommands": [
{
"description": "Enable pretty-printing for gdb",
"text": "-enable-pretty-printing",
"ignoreFailures": true
}
]
}
]
}
(2)tasks.json
{
// See https://go.microsoft.com/fwlink/?LinkId=733558
// for the documentation about the tasks.json format
"version": "2.0.0",
"tasks": [
{
"label": "build",
"type": "shell",
"command": "g++",
"args": ["-g", "${file}", "-std=c++11", "-o", "${fileBasenameNoExtension}.out"]
}
]
}
總結(jié)
到此這篇關(guān)于Ubuntu16.04下配置VScode的C/C++開發(fā)環(huán)境的文章就介紹到這了,更多相關(guān)Ubuntu16.04下配置VScode的C/C++開發(fā)環(huán)境內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于C語(yǔ)言實(shí)現(xiàn)創(chuàng)意多彩貪吃蛇游戲
這篇文章主要介紹了如何利用C語(yǔ)言實(shí)現(xiàn)一個(gè)創(chuàng)意多彩貪吃蛇游戲,這是一個(gè)純C語(yǔ)言外加easyx庫(kù)的繪圖函數(shù)制作而成的有趣小游戲,無需引入額外資源,感興趣的可以動(dòng)手嘗試一下2022-08-08
C++設(shè)計(jì)模式之迭代器模式(Iterator)
這篇文章主要為大家詳細(xì)介紹了C++設(shè)計(jì)模式之迭代器模式Iterator,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
C++優(yōu)先級(jí)隊(duì)列的使用指南與模擬實(shí)現(xiàn)
優(yōu)先級(jí)隊(duì)列是一種特殊的隊(duì)列,其中每個(gè)元素都有一個(gè)與之關(guān)聯(lián)的優(yōu)先級(jí),優(yōu)先級(jí)較高的元素會(huì)在隊(duì)列中較早地被處理,而優(yōu)先級(jí)較低的元素會(huì)在后續(xù)處理,本文給大家介紹C++優(yōu)先級(jí)隊(duì)列的使用指南與模擬實(shí)現(xiàn),需要的朋友可以參考下2023-09-09
C++類和對(duì)象實(shí)戰(zhàn)之Date類的實(shí)現(xiàn)方法
C++ 標(biāo)準(zhǔn)庫(kù)沒有提供所謂的日期類型,C++ 繼承了C語(yǔ)言用于日期和時(shí)間操作的結(jié)構(gòu)和函數(shù),這篇文章主要給大家介紹了C++類和對(duì)象實(shí)戰(zhàn)之Date類的實(shí)現(xiàn)方法,需要的朋友可以參考下2021-12-12

