vscode配置

前言

工欲善其事必先利其器。我当初学习编码那会,使用的dev c++。后来系统切换成linux后,一直使用的是vscode。工作的时候,调试程序的时候开始使用vs。

目前而言,我喜欢使用vscode这个编辑器。下面记录使用过程。


插件

  1. 同步功能。vscode的配置同步,现在不需要使用插件了。使用见:Settings Sync 设置同步VSCode官方的配置同步方案
  2. 代码格式化:C++代码格式化
  3. 远程连接,直接在服务器上开发(如果提示等功能缺失了,点击插件安装下):Remote-SSH
  4. GitLens:GitLens 教程: 如何在 VS Code 中使用 GitLens。我最喜欢的是它侧边栏的源码管理,在提交代码前,查看下做了哪些修改。
  5. Live Server: http://ip:5500。在wsl中的html文件,不好用浏览器直接打开。使用这个插件,可以访问wsl的5500端口,即可查看html文件。方便的很。

C++调试配置

在Linux中,我习惯用vscode写C++代码。下面介绍linux下vscode的调试。至于windows下的调试,使用VS是最方便不过的了。

先手动创建工程。

➜  tree
.
├── doc # 文档目录
├── README.md # 介绍
└── src # 源码目录

我们在src目录中添加一个main.cppCMakeLists.txt

// main.cpp
#include <iostream>

using namespace std;

int main(void)
{
    cout<<"Hello World"<<endl;
}
cmake_minimum_required(VERSION 3.5)

project (main)

add_executable(${PROJECT_NAME} main.cpp)

此时,我们来编译代码。

cd src
mkdir build && cd build
cmake ..
make

此时,我们如何使用vscode的调试功能呢? 我不咋会用gdb,我需要使用vscode的调试功能。

即,vscode中,通过cmake->make编译的代码,如何调试。


Using C++ on Linux in VS Code

我们需要阅读vscode的配置文档:Using C++ on Linux in VS Code

vscode中编译过程配置

编译这一节,我用不到。顺带看下吧。我推荐直接在命令行进行编译。

从主菜单中,选择终端>配置默认构建任务。将出现一个下拉列表,显示 C++ 编译器的各种预定义构建任务。选择C/C++: g++ build active file。

此时在当前项目的根目录中,出现了.vscode/tasks.json文件。内容如下:

{
	"version": "2.0.0",
	"tasks": [
		{
			"type": "cppbuild",
			"label": "C/C++: g++ 生成活动文件",
			"command": "/usr/bin/g++",
			"args": [
				"-fdiagnostics-color=always",
				"-g",
				"${file}",
				"-o",
				"${fileDirname}/${fileBasenameNoExtension}"
			],
			"options": {
				"cwd": "${fileDirname}"
			},
			"problemMatcher": [
				"$gcc"
			],
			"group": {
				"kind": "build",
				"isDefault": true
			},
			"detail": "编译器: /usr/bin/g++"
		}
	]
}

command设置指定要运行的程序;在这种情况下是 g++。该args数组指定将传递给 g++ 的命令行参数。这些参数必须按照编译器预期的顺序指定。

这个任务告诉g++获取活动${file}文件。生成文件放入该文件去除后缀名。

该label值是您将在任务列表中看到的;你可以随意命名它。

对象中的"isDefault": true值指定当您按Ctrl+Shift+B group时将运行此任务。此属性仅为方便起见;如果您将其设置为 false,您仍然可以从 Terminal 菜单中使用Tasks: Run Build Task运行它。

当然,我们可以修改tasks.json,使得一键编译。

修改方式一,来自:vscode + cmake编译环境配置

{
    // See https://go.microsoft.com/fwlink/?LinkId=733558
    // for the documentation about the tasks.json format
    "version": "2.0.0",
    "tasks": [
        {
            "label": "make build",//编译的项目名,build,更改
            "type": "shell",
            "command": "cd ./src/build ;cmake ../ ;make",//编译命令,更改
            "group": {
                "kind": "build",
                "isDefault": true
            }
        },
        {
            "label": "clean",
            "type": "shell",
            "command": "make clean",
        }
    ]
}

点击中断->运行任务…,便可以选择不同的任务(label标记)运行。

修改方式二,来自:使用VSCODE生成调试Linux下C++的CMake项目。这个修改,比上一个好。

{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "mkdir",
      "type": "shell",
      "command": "mkdir build -p"
    },

    {
      "label": "cmake",
      "type": "shell",
      "command": "cmake -DCMAKE_BUILD_TYPE=debug ..",
      "dependsOn": ["mkdir"], 
      "options": {
        "cwd": "${workspaceFolder}/build" 
      },
    },

    {
      "label": "make",
      "type": "shell",
      "command": "make -j4",
      "options": {
        "cwd": "${workspaceFolder}/build" 
      },
    }
  ]
}

vscode中调试配置

这是我们关注的小节

接下来,您将创建一个launch.json文件来配置 VS Code,以便在您按F5调试程序时启动 GDB 调试器。

从主菜单中,选择**Run > Add Configuration…**然后选择C++ (GDB/LLDB)。

VS Code 创建一个launch.json文件,在编辑器中打开它。如下所示:

{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": []
}

右键,或者点击右下角的“添加配置” --> 添加gdb调试。此时的配置文件内容有所增加,如下所示:

{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) 启动",
            "type": "cppdbg",
            "request": "launch",
            "program": "输入程序名称,例如 ${workspaceFolder}/a.out",
            "args": [],
            "stopAtEntry": false,
            "cwd": "${fileDirname}",
            "environment": [],
            "externalConsole": false,
            "MIMode": "gdb",
            "setupCommands": [
                {
                    "description": "为 gdb 启用整齐打印",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                },
                {
                    "description":  "将反汇编风格设置为 Intel",
                    "text": "-gdb-set disassembly-flavor intel",
                    "ignoreFailures": true
                }
            ]
        }

    ]
}

在上面的 JSON 中,program指定要调试的程序。此处其默认设置为项目根目录下的a.out文件。

默认情况下,C++ 扩展不会向您的源代码添加任何断点,并且该stopAtEntry值设置为false.

stopAtEntry将值更改为true以使调试器main在您开始调试时停止该方法。

setupCommands: 设置GDB或LLDB的命令的JSON数组。

所以,我们暂时只需要修改"program"

{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) 启动",
            "type": "cppdbg",
            "request": "launch",
            "program": "${fileDirname}/build/${fileBasenameNoExtension}",
            // "program": "${workspaceFolder}/build/result",
            "args": [],
            "stopAtEntry": false,
            "cwd": "${fileDirname}",
            "environment": [],
            "externalConsole": false,
            "MIMode": "gdb",
            "setupCommands": [
                {
                    "description": "为 gdb 启用整齐打印",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                },
                {
                    "description":  "将反汇编风格设置为 Intel",
                    "text": "-gdb-set disassembly-flavor intel",
                    "ignoreFailures": true
                }
            ]
        }

    ]
}

vscode中C/C++配置

我们会在src目录的外面,建立一个include目录,来放置头文件。

有时候,vscode不大聪明:源码中包含了对应的头文件,但编辑的时候,下方会有红色的波浪线,提示未定义。有时候,这个挺讨厌的。我们需要添加它的头文件扫描路径。

您可以创建一个c_cpp_properties.json文件,该文件将允许您更改设置,例如编译器的路径、包含路径、C++ 标准(默认为 C++17)等等。

您可以通过运行命令C/C++: Edit Configurations (UI) from the Command Palette ( Ctrl+Shift+P ) 来查看 C/C++ 配置 UI。点击左下角,可以切换使用不同的配置。

我们来看下c_cpp_properties.json中的内容。

{
    "configurations": [
        {
            "name": "Linux Config",
            "includePath": [
                "${workspaceFolder}/**"
            ],
            "defines": [
                "__linux__",
                "__x86_64__",
                "_GNU_SOURCE"
            ],
            "compilerPath": "/usr/bin/g++",
            "cStandard": "c17",
            "cppStandard": "c++14",
            "intelliSenseMode": "linux-clang-x64"
        },
        {
            "name": "Windows Config",
            "includePath": [
                "${workspaceFolder}/**",
                "C:/Qt/6.4.2/msvc2019_64/include",
                "C:/Boost/include"
            ],
            "defines": [
                "WINDOWS"
            ],
            "compilerPath": "C:/Program Files (x86)/Microsoft Visual Studio/2019/Community/VC/Tools/MSVC/14.29.30133/bin/Hostx64/x64/cl.exe",
            "cStandard": "c17",
            "cppStandard": "c++14"
        }
    ],
    "version": 4
}

可以在"includePath"中添加一些路径。


实际案例

调试openssl

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "gdb-opnessl",
            "type": "cppdbg",
            "request": "launch",
            "program": "/home/dacao/work/openssl-learn/openssl/apps/openssl", // 被调试程序的绝对路径
            "args": ["dgst", "-sign", "./tmp/private_key.pem", "-sha256", "-out", "./tmp/rsa-sign.dat", "./tmp/plain.dat"],
            "stopAtEntry": true,
            "cwd": "/home/dacao/work/openssl-learn", // 进入的目录
            "environment": [
                {
                    "name":"LD_LIBRARY_PATH",
                    "value":"/home/dacao/work/openssl-learn/openssl:$LD_LIBRARY_PATH"
                }
            ],
            "console":"none",
            "MIMode": "gdb",
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                }
            ]
        }
    ]
}

vscode调试的其他问题

Visual Studio Code(VSCode)是一个轻量级但功能强大的源代码编辑器,由微软开发。它支持多种编程语言的开发,包括C++。要配置VSCode以进行C++开发,你需要按照以下步骤操作: 1. 安装VSCode:首先确保你的系统上已经安装了VSCode。 2. 安装C++扩展:在VSCode中打开扩展视图(使用快捷键`Ctrl+Shift+X`或`Cmd+Shift+X`),搜索并安装C/C++扩展,由Microsoft提供。这个扩展提供了对C++语言的智能感知、调试支持等功能。 3. 配置编译器:你需要为VSCode配置C++编译器。在Windows上,你可以使用MinGW或Visual Studio的编译器;在Linux上,可以使用GCC;在macOS上,可以使用Clang。通常情况下,如果你已经安装了Visual Studio或相应的命令行工具,VSCode将能够自动检测到这些工具。 4. 创建或打开项目:你可以创建一个新的C++项目,或者打开一个已有的项目。VSCode将使用工作区(workspace)的概念来管理项目文件。 5. 编辑c_cpp_properties.json:在VSCode中,打开一个C++文件,然后在右下角的状态栏中,点击“C/C++”环境,选择“Edit in settings.json”来配置编译器路径、包含路径、库路径等。 6. 设置构建任务:为了编译项目,你需要定义构建任务。可以通过`Ctrl+Shift+P`打开命令面板,输入“Tasks: Configure Task”来自动生成一个基本的构建任务。然后根据你的项目配置,修改这个任务定义文件。 7. 使用终端进行构建和运行:VSCode集成了一个终端,你可以直接在VSCode内运行构建命令和程序。 8. 调试程序:配置好`launch.json`文件后,你就可以在VSCode中设置断点,启动调试会话。 通过上述步骤,你就可以在VSCode配置并开始C++编程了。当然,根据不同的需求,可能还需要进行更多的个性化配置
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

da1234cao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值