linux适应环境,Linux从入门到适应(一):VSCode C++环境配置
作為在Windows環(huán)境下習(xí)慣使用Visual Studio IDE的人,對于Linux環(huán)境下的Vim編輯使用十分難受,雖然網(wǎng)上很多人說vim非常牛逼和強(qiáng)大,但是我更加習(xí)慣于使用VS code的界面,所以我選擇VS code作為編輯器使用。
VS code本身是一個(gè)編輯器,所以如果需要調(diào)試等功能需要自己安裝一些插件,并且配置相關(guān)的json文件。
linux 環(huán)境下,g++和clang都可以作為C++的編譯器,我這里選擇使用的是clang。
首先是插件選擇:
(1)?C/C++ 微軟自帶的C/C++插件。
(2)?C/C++ Clang Command Adapter:提供靜態(tài)檢測(Lint)
(3)?Code Runner:右鍵即可編譯運(yùn)行單文件
(4)?Bracket Pair Colorizer:彩虹花括號
(5)?Include Autocomplete:提供頭文件名字的補(bǔ)全
以上插件下載完之后,在文件工作區(qū)(workspace) 新建一個(gè)文件夾作為你項(xiàng)目的根目錄文件,然后新建一個(gè)".vscode" 文件,該文件夾存放相關(guān)json的配置文件,其中l(wèi)aunch.json 和tasks.json 兩個(gè)配置文件是必須的,除了這兩個(gè)之外,還可以加上setting.json。如果setting.json不加設(shè)置,就會使用設(shè)置,基本上滿足使用了。
關(guān)于,launch.json的配置為:
// https://github.com/Microsoft/vscode-cpptools/blob/master/launch.md
{
"version": "0.2.0",
"configurations": [
{
"name": "(gdb) Launch", // 配置名稱,將會在啟動配置的下拉菜單中顯示
"type": "cppdbg", // 配置類型,這里只能為cppdbg
"request": "launch", // 請求配置類型,可以為launch(啟動)或attach(附加)
"program": "${fileDirname}/${fileBasenameNoExtension}.out", // 將要進(jìn)行調(diào)試的程序的路徑
"args": [], // 程序調(diào)試時(shí)傳遞給程序的命令行參數(shù),一般設(shè)為空即可
"stopAtEntry": false, // 設(shè)為true時(shí)程序?qū)和T诔绦蛉肟谔?#xff0c;我一般設(shè)置為true
"cwd": "${workspaceFolder}", // 調(diào)試程序時(shí)的工作目錄
"environment": [], // (環(huán)境變量?)
"externalConsole": true, // 調(diào)試時(shí)是否顯示控制臺窗口,一般設(shè)置為true顯示控制臺
"internalConsoleOptions": "neverOpen", // 如果不設(shè)為neverOpen,調(diào)試時(shí)會跳到“調(diào)試控制臺”選項(xiàng)卡,你應(yīng)該不需要對gdb手動輸命令吧?
"MIMode": "gdb", // 指定連接的調(diào)試器,可以為gdb或lldb。但目前l(fā)ldb在windows下沒有預(yù)編譯好的版本。
// "miDebuggerPath": "gdb.exe", // 調(diào)試器路徑,Windows下后綴不能省略,Linux下則去掉
"setupCommands": [ // 用處未知,模板如此
{
"description": "Enable pretty-printing for gdb",
"text": "-enable-pretty-printing",
"ignoreFailures": false
}
],
"preLaunchTask": "Compile" // 調(diào)試會話開始前執(zhí)行的任務(wù),一般為編譯程序。與tasks.json的label相對應(yīng)
}
]
}
tasks.json的配置為:
// https://code.visualstudio.com/docs/editor/tasks
{
"version": "2.0.0",
"tasks": [
{
"label": "Compile", // 任務(wù)名稱,與launch.json的preLaunchTask相對應(yīng)
"command": "clang++", // 要使用的編譯器 clang++ 或者g++
"args": [
"${file}",
"-o", // 指定輸出文件名,不加該參數(shù)則默認(rèn)輸出a.exe,Linux下默認(rèn)a.out
"${fileDirname}/${fileBasenameNoExtension}.out",
"-g", // 生成和調(diào)試有關(guān)的信息
"-Wall", // 開啟額外警告
"-static-libgcc", // 靜態(tài)鏈接
// "-fcolor-diagnostics", // 彩色的錯誤信息?但貌似clang默認(rèn)開啟而gcc不接受此參數(shù)
// "--target=x86_64-w64-mingw", // clang的默認(rèn)target為msvc,不加這一條就會找不到頭文件;Linux下去掉這一條
"-std=c++11" // C語言最新標(biāo)準(zhǔn)為c11,或根據(jù)自己的需要進(jìn)行修改
], // 編譯命令參數(shù)
"type": "shell", // 可以為shell或process,前者相當(dāng)于先打開shell再輸入命令,后者是直接運(yùn)行命令
"group": {
"kind": "build",
"isDefault": true // 設(shè)為false可做到一個(gè)tasks.json配置多個(gè)編譯指令,需要自己修改本文件,我這里不多提
},
"presentation": {
"echo": true,
"reveal": "always", // 在“終端”中顯示編譯信息的策略,可以為always,silent,never。具體參見VSC的文檔
"focus": false, // 設(shè)為true后可以使執(zhí)行task時(shí)焦點(diǎn)聚集在終端,但對編譯c和c++來說,設(shè)為true沒有意義
"panel": "shared" // 不同的文件的編譯信息共享一個(gè)終端面板
}
// "problemMatcher":"$gcc" // 如果你不使用clang,去掉前面的注釋符,并在上一條之后加個(gè)逗號。照著我的教程做的不需要改(也可以把這行刪去)
}
]
}
然后ctrl+shift+B是編譯,按F5是編譯+運(yùn)行。
以上是VS Code在Linux環(huán)境下使用的基本操作,日后有什么新的技能和發(fā)現(xiàn)我會更新或者修正。
總結(jié)
以上是生活随笔為你收集整理的linux适应环境,Linux从入门到适应(一):VSCode C++环境配置的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: android air创建文件夹,安卓版
- 下一篇: 手电筒android studio,An