在Linux系统下使用VS Code编写调试C++代码的配置流程

在Linux系统下使用VS Code编写调试C++代码的配置流程

记录一下在linux系统中使用vscode编写调试C++代码的配置过程。

1.随意编写运行代码

首先打开VSCode,创建一个工作区,建立一个cpp文件。这里用helloworld来举例。

#include <iostream>
using namespace std;

int main()
{
    cout << "hello world" << endl;
    return 0;
} 

2.配置task.json

编写完成代码后,用ctrl+shift+P调出命令行,选择Tasks:Configure Task即配置任务,然后选择使用模板生成task.json,然后任务模板选择Others,此时自动生成task.json。将task.json中的内容替换为:

{
    // See https://go.microsoft.com/fwlink/?LinkId=733558
    // for the documentation about the tasks.json format
    "version": "2.0.0",
    "tasks": [
        {
            "label": "build", //在launch.json文件中有用到
            "type": "shell",
            "command": "g++",
            "args": [
                "-g", "${file}","-o","${fileDirname}/${fileBasenameNoExtension}.out"
            ],
            "group": {
                "kind": "build",
                "isDefault": true
            }
        }
    ]
}

args这样写的目的是为了后面使用统一配置,并方便.out调试文件输出到指定的目录下。

3.配置launch.json

为了后面调试需要,配置launch.json文件。在绿色箭头右边的配置区内选择C++(GDB),由于我已经配置好了,因此这里的配置会显示launch.json的name名称。
在这里插入图片描述

在选择完成后会自动生成json文件,将launch.json中的内容改为如下内容:

{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) Launch",                                 //配置名称,会在启动配置的下拉菜单中显示
            "type": "cppdbg",                                       //配置类型,只能为cppdbg
            "request": "launch",                                    //请求类型,可以为launch或attach
            "program": "${fileDirname}/${fileBasenameNoExtension}.out",             //将要调试的程序的路径
            "args": [],                                             //调试时传递给程序的命令行参数
            "stopAtEntry": false,                                   //设为true程序会暂停在入口处
            "cwd": "${workspaceFolder}",                            //调试程序时的工作目录
            "environment": [],                                      //环境变量
            "externalConsole": false,                                //调试时是否显示控制台窗口
            "MIMode": "gdb",                                        //指定连接的调试器,可以为gdb或lldb
            "miDebuggerPath": "/usr/bin/gdb",                       //gdb路径
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                }
            ],
            "preLaunchTask": "build"                                //调试开始前执行的任务,一般为编译程序
        }
    ]
}

其中几个需要注意的点:

  1. name参数是为了给配置做名称上的区分;
  2. program需要跟task.json中生成的out路径对应,这里为了让后面的项目都可以使用这个配置,因此将每个项目的.out文件生成在对应项目下;
  3. miniDebuggerPath代表的gdb路径需要根据linux命令where is gcc确定;
  4. preLaunchTask的任务名称需要跟task.json中的label名称对应,在调试前需要先编译。

4.直接加入c_cpp_properties.json

通过Ctrl+Shift+P运行C/CPP: Edit configuration ...命令添加缺少的信息并生成c_cpp_properties.json文件。

这里的json文件内容我没有进行修改。

5.最终效果展示

文件配置过程有点麻烦,因此我将配置好的.vscode放置在其他文件夹上层,这样工作区VisualCode内的项目都可以使用同样的配置,而且task.json和launch.json中的写法也能够保证调试过程中的文件产生在相应的文件夹下。

在这里插入图片描述
最终达到的效果就是,主目录下的helloworld.cpp以及practise文件夹下的test.cpp都可以通过配置好的json文件进行编译及调试。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【资源说明】 1、该资源包括项目的全部源码,下载可以直接使用! 2、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和毕设项目,作为参考资料学习借鉴。 3、本资源作为“参考资料”如果需要实现其他功能,需要能看懂代码,并且热爱钻研,自行调试。 基于zigbee和stm32的智能家居系统源码+项目说明,上位机使用Qt编写(毕业设计).zip # 基于 Zigbee 和 STM32 的环境监测监控系统 项目设计、开发文档、以及开发资料获取方式: <div align=left> ## 安全认证 [![Security Status](https://www.murphysec.com/platform3/v3/badge/1614013746192613376.svg?t=1)](https://www.murphysec.com/accept?code=69f7806ceb54b7d3e1a8a09bff768c88&type=1&from=2&t=2) ## 项目介绍 本系统分为硬件和软件两部分内容,下位机 `STM32` 单片机驱动各个传感器模块采集数据,然后发送给 `ZigBee` 终端,`ZigBee` 终端在接收到数据后发送给协调器,协调器是和 `ARM`开发板(上位机)相连接的,`ARM` 开发板收到数据后进行相应的解析并显示在界面上。其中ARM开发板上跑的是使用 `Qt` 编写的程序,经过交叉编译后移植到了开发板上。 ![framework](./screen/framework.png) 有关该项目详细使用说明,可以看这边博客,介绍的比较详细.[传送门][3] ## 开发环境 ``` 开发系统:Windows10 64位 Ubuntu 14.04 32 位 软件版本:Qt 4.8.6 IAR .0 Altium Designer 13.0 工具链:arm-linux-gcc 4.4.3 ``` 目前已经支持 `Qt5` 编译运行 ## 编译和运行 ### 下载代码到本地 ``` git clone [email protected]:kevinlq/SmartHome-Qt.git cd SmartHome-Qt qmake SmartHomeV5.pro ``` ### 使用Qt4打开直接编译 为什么说是Qt4呢,因为当时编写基于ARM Linux 平台,使用的是Qt4,在Qt5中有一些函数方法被取消了。如果你在windows下或者其他平台使用非Qt4,那么需要自己进行修改! ### 运行 程序运行需要数据库,默认使用 `QSqlLite` 数据库,需要拷贝 `file`文件夹下的 `SmartHome.db` 文件到可执行程序同级目录下 >默认程序编译完成后,可执行程序在bin目录下 可以在工程配置文件中进行修改! ``` DESTDIR = $$PWD/bin ``` 关于交叉编译,移植到ARM平台,可以参考我的这篇文档,介绍很详细! [传输门][2] 如果有什么问题欢迎及时联系我 ## 系统功能 详细的介绍可以看博客[http://blog.csdn.net/u013704336/article/details/51765397][1] 这个项目作为2016年的毕设,完美完成了各项要求。综合利用了所学的C语言、C++、zigbee、stm32、Qt、ARM、等嵌入式技术。 ### 首页 ![Image text](/screen/home.png) ### 控制主界面 ![Image text](/screen/controlHome.png) ### 客厅 ![Image text](screen/parlour.png) ### 卧室 ![Image text](/screen/bedroom.png) ### 厨房 ![Image text](/screen/kitchen.png) ### 历史曲线数据 ![Image text](/screen/temp.png) ![Image text](/screen/smoke.png) ![Image text](/screen/hum.png) ## 电路原理图 电路图使用AD13软件进行绘制,使用的主控芯片是STM32F103 ![Image text](/screen/stm32.png) ## Change Logs - .... - 2018-10.14-添加程序编译及运行配置(最近有不少人问,总是编译失败,所以完善了下) - 2020.03.11 兼容Qt5,
Linux使用VS Code进行快速调试C语言的步骤如下: 1. 首先,确保你的Linux系统已经安装了GCC编译器。如果没有安装,可以通过在终端中运行以下命令来安装: ``` sudo apt-get update sudo apt-get install build-essential ``` 2. 下载并安装VS Code。可以通过官方网站下载并按照指示安装。 3. 打开VS Code后,在左侧的扩展栏中搜索并安装C/C++扩展。 4. 创建一个新的C语言项目。选择“File”菜单中的“New File”,然后将文件保存为以`.c`为扩展名的文件。 5. 编写你的C源代码。 6. 在顶部菜单栏中选择“View” -> “Command Palette”(或使用键盘快捷键Ctrl+Shift+P)。然后在搜索框中输入“C/C++: Select a configuration”,选择“C/C++: Select a configuration”,选择“GCC”,以便配置C/C++扩展使用GCC编译器。 7. 接下来,在顶部菜单栏中选择“Run” -> “Add Configuration”,然后选择“C/C++: (gdb) Launch”作为调试器。 8. 在VS Code中的`launch.json`文件中,添加以下配置: ```json "version": "0.2.0", "configurations": [ { "name": "C/C++: (gdb) Launch", "type": "cppdbg", "request": "launch", "program": "${workspaceFolder}/your_code.c", "args": [], "stopAtEntry": false, "cwd": "${workspaceFolder}", "environment": [], "externalConsole": false, "MIMode": "gdb", "miDebuggerPath": "/usr/bin/gdb" } ] ``` 将`"program"`字段的值更改为你的C代码文件路径。 9. 现在,你可以在VS Code的编辑器窗口中设置断点。点击行号旁边的空白区域即可设置断点。 10. 最后,点击顶部菜单栏中的“Run”按钮或使用快捷键F5来开始调试你的C程序。 以上就是在Linux使用VS Code进行快速调试C语言的步骤。在调试过程中,可以使用VS Code提供的调试控制台来查看程序的输出和变量的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值