在 Ubuntu 中用 VSCode 配置 C 语言项目的编译与调试(详解教程)

目录

    • 一、准备工作
    • 二、配置 VSCode 的编译任务
    • 三、配置 VSCode 的调试任务
    • 四、编译与调试流程
    • 五、常见问题排查
    • 六、总结

在 C 语言开发过程中,调试与编译是不可缺少的环节,而 VSCode(Visual Studio Code)作为一个强大且轻量级的编辑器,结合 gcc 和 gdb,可以高效地完成 C 语言项目的开发和调试工作。本文将详细介绍如何在 Ubuntu 环境下,用 VSCode 配置一个 C 项目的编译和调试环境。

一、准备工作

1. 安装必要工具
在开始之前,确保你的系统已经安装了以下工具:

VSCode:通过终端安装:

sudo apt update
sudo apt install code

GCC 和 GDB:用于编译和调试 C 程序。

sudo apt install build-essential gdb

VSCode C/C++ 插件:打开 VSCode,点击左侧扩展(Extensions)图标,搜索 C/C++,安装由 Microsoft 提供的插件。

2. 准备项目文件
将你的 C 项目文件放在一个独立的目录中。例如:

~/AGC/test_AGC/

项目文件结构示例如下:

test_AGC/
├── agc.c
├── agc.h
├── dr_wav.h
├── WebRTC_AGC.c
└── build/  # 用于存放编译输出文件

二、配置 VSCode 的编译任务

为了方便管理项目,我们需要在 VSCode 中配置编译任务。这些任务会自动调用 gcc,将源代码编译成可执行文件,并输出到指定目录中。

1. 创建 tasks.json
在项目的根目录下新建 .vscode/tasks.json 文件,内容如下:

{
	"version": "2.0.0",
	"tasks": [
		{
			"type": "cppbuild",
			"label": "C/C++: gcc build Debug version",
			"command": "/usr/bin/gcc",
			"args": [
				"-fdiagnostics-color=always",
				"-g",
				"${file}",
				"-o",
				"${workspaceFolder}/build/Debug/outDebug"
			],
			"options": {
				"cwd": "${workspaceFolder}"
			},
			"problemMatcher": ["$gcc"],
			"group": {
				"kind": "build",
				"isDefault": true
			},
			"detail": "Generated build task for Debug version",
			"dependsOn": ["createBuildDir"]
		},
		{
			"label": "createBuildDir",
			"type": "shell",
			"command": "mkdir",
			"args": ["-p", "${workspaceFolder}/build/Debug"],
			"problemMatcher": []
		}
	]
}

2. 配置说明
label:任务名称,可用于在任务面板中调用。
command:指定编译器路径,这里是 /usr/bin/gcc。
args:
-g:生成包含调试信息的可执行文件。
${file}:表示当前正在编辑的 C 文件。
-o:指定输出文件路径,这里是 build/Debug/outDebug。
dependsOn:确保在编译前自动创建目标目录 build/Debug。
cwd:设置当前工作目录为项目的根目录 ${workspaceFolder}。
3. 执行编译任务
按下 Ctrl+Shift+B 或通过菜单选择 Terminal -> Run Build Task。如果任务配置正确,将会生成编译输出文件:

~/AGC/test_AGC/build/Debug/outDebug

三、配置 VSCode 的调试任务

有了编译任务之后,我们需要为项目配置调试器,以便单步运行代码、设置断点、查看变量等。

1. 创建 launch.json
在项目的 .vscode 文件夹中,创建一个名为 launch.json 的文件,内容如下:

{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "C/C++ Runner: Debug Session",
      "type": "cppdbg",
      "request": "launch",
      "args": [],
      "stopAtEntry": false,
      "externalConsole": false,
      "cwd": "${workspaceFolder}",
      "program": "${workspaceFolder}/build/Debug/outDebug",
      "MIMode": "gdb",
      "miDebuggerPath": "/usr/bin/gdb",
      "setupCommands": [
        {
          "description": "Enable pretty-printing for gdb",
          "text": "-enable-pretty-printing",
          "ignoreFailures": true
        }
      ]
    }
  ]
}

2. 配置说明
program:指定调试目标文件路径,需与编译输出路径一致。
cwd:调试时的工作目录,通常设置为项目根目录。
MIMode:调试模式,使用 gdb。
miDebuggerPath:gdb 的路径,通常为 /usr/bin/gdb。

四、编译与调试流程

1. 执行编译任务
在 VSCode 中,按 Ctrl+Shift+B 执行编译任务,生成可执行文件 build/Debug/outDebug。如果一切正常,在终端中运行以下命令可以看到生成的文件:

ls ~/AGC/test_AGC/build/Debug/

输出示例:

outDebug

2. 设置断点
打开 agc.c 文件,点击行号左侧的空白区域,添加断点(红点会显示出来)。

3. 启动调试
按下 F5 或点击调试按钮(虫子图标),选择 C/C++ Runner: Debug Session。调试器将启动,并在断点处暂停。

五、常见问题排查

1. 编译失败:找不到输出目录
如果遇到错误:

/usr/bin/ld: cannot open output file ...: No such file or directory

这是因为目标目录不存在。确保 tasks.json 中已包含 mkdir 命令,或手动运行以下命令:

mkdir -p ~/AGC/test_AGC/build/Debug

2. 中文路径问题
如果路径中有中文字符(如 桌面),可能会导致工具解析失败。建议将项目移动到全英文路径下,如:

mkdir -p ~/projects
mv ~/AGC/test_AGC ~/projects/

3. 调试器无法启动
如果调试器提示:

launch: program ... does not exist

请确保 launch.json 中的 program 路径与实际编译输出路径一致。

六、总结

通过以上配置,VSCode 已经成为一个强大的 C 语言开发环境。无论是编译还是调试,都可以在一个统一的界面中完成。以下是完整的操作流程回顾:

在 VSCode 中配置 tasks.json,自动编译 C 代码。
在 VSCode 中配置 launch.json,设置调试器。
使用 Ctrl+Shift+B 进行编译,按 F5 进入调试模式。
利用断点和调试器功能,快速定位和解决代码中的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/920756.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SpringCloud篇(服务保护 - Sentinel)

目录 一、雪崩问题及解决方案 1. 雪崩问题 2. 解决方案 方案一:超时处理 方案二:仓壁模式 方案三:断路器模式 方案四:限流 3. 总结 二、服务保护技术对比 三、Sentinel介绍与安装 1. 初识Sentinel 2. Sentinel 优势 3…

MACOS开发、使用常见问题汇总

MACOS常见问题 本文记录使用macos遇到的常见问题,后面会持续更新,觉得有用的可以收藏一下。 打不开xxx.app,因为它来自身份不明的开发者解决方法(开启任何来源) 打开终端(Terminal)程序 拷贝sudo spctl --master-di…

网络安全之国际主流网络安全架构模型

目前,国际主流的网络安全架构模型主要有: ● 信息技术咨询公司Gartner的ASA(Adaptive Security Architecture自适应安全架构) ● 美国政府资助的非营利研究机构MITRE的ATT&CK(Adversarial Tactics Techniques &…

Linux下 GDB调试器的使用

文章目录 1. 可执行程序的Debug版和Release版区别一、编译选项与目的二、性能与体积三、功能与特性四、查看可执行文件 2. GDB 相关命令GDB常用命令 1. 可执行程序的Debug版和Release版区别 一、编译选项与目的 Debug版: 编译选项:通常使用包含调试信息…

RN开发搬砖经验之—Layout Inspector看不到 DecorView

最近我发现自己已经很久没有使用Layout Inspector这个工具了。今天,为了深入分析React Native(RN)框架中的一个UI问题,我需要查看RN组件对应的Android原生组件视图层级(View tree)的实际情况。因此&#xf…

go-zero(三) 数据库操作

go-zero 数据库操作 在本篇文章中,我们将实现一个用户注册和登录的服务。我们将为此构建一个简单而高效的 API,包括请求参数和响应参数的定义。 一、Mysql连接 1. 创建数据库和表 在 MySQL 中创建名为 test_zero的数据库,并创建user 表 …

23种设计模式-模板方法(Template Method)设计模式

文章目录 一.什么是模板方法模式?二.模板方法模式的特点三.模板方法模式的结构四.模板方法模式的应用场景五.模板方法模式的优缺点六.模板方法模式的C实现七.模板方法模式的JAVA实现八.代码解析九.总结 类图: 模板方法设计模式类图 一.什么是模板方法模…

uniapp实现开发遇到过的问题(持续更新中....)

1. 在ios模拟器上会出现底部留白的情况 解决方案: 在manifest.json文件,找到开源码视图配置,添加如下: "app-plus" : {"safearea":{"bottom":{"offset" : "none" // 底部安…

Python Matplotlib 安装指南:使用 Miniconda 实现跨 Linux、macOS 和 Windows 平台安装

Python Matplotlib 安装指南:使用 Miniconda 实现跨 Linux、macOS 和 Windows 平台安装 Matplotlib是Python最常用的数据可视化工具之一,结合Miniconda可以轻松管理安装和依赖项。在这篇文章中,我们将详细介绍如何使用Miniconda在Linux、mac…

【element-tiptap】Tiptap编辑器核心概念----结构篇

core-concepts 前言:这篇文章来介绍一下 Tiptap 编辑器的一些核心概念 (一)结构 1、 Schemas 定义文档组成方式。一个文档就是标题、段落以及其他的节点组成的一棵树。 每一个 ProseMirror 的文档都有一个与之相关联的 schema,…

window的wsl(Ubuntu)安装kafka步骤

环境:Win11 WSL(Linux子系统Ubuntu) apache-zookeeper-3.9.3-bin kafka_2.12-3.8.1 思路:apache上分别下载zookeeper和kafka,在wsl环境安装。在kafka上创建消息的topic,发送消息,接受消息,验证是否安…

Notepad++--在开头快速添加行号

原文网址:Notepad--在开头快速添加行号_IT利刃出鞘的博客-CSDN博客 简介 本文介绍Notepad怎样在开头快速添加行号。 需求 原文件 想要的效果 方法 1.添加点号 Alt鼠标左键,从首行选中首列下拉,选中需要添加序号的所有行的首列&#xff…

机器学习基础06_梯度下降

目录 一、为什么使用梯度下降 二、什么是梯度下降 三、为什么要用梯度下降 四、怎么进行梯度下降 1、微分 1.单变量的微分 2.多变量的微分 2、梯度 3、步骤 (1)学习率α (2)梯度(导数)前的负号 4、实例实现 五、sklearn梯度下降 一、为什么使用梯度下降 前面利用正…

《Vue零基础入门教程》第二课:搭建开发环境

往期内容: 《Vue零基础入门教程》第一课:Vue简介 1 搭建开发环境 Vue环境分为两种 不使用构建工具使用构建丁具 首先,我们会介绍 不使用构建工具 的环境,在组件化章节中介绍 使用构建工具 的方式 1) 初始化 使用如下指令初始化 npm i…

【IDEA】解决总是自动导入全部类(.*)问题

文章目录 问题描述解决方法 我是一名立志把细节说清楚的博主,欢迎【关注】🎉 ~ 原创不易, 如果有帮助 ,记得【点赞】【收藏】 哦~ ❥(^_-)~ 如有错误、疑惑,欢迎【评论】指正探讨,我会尽可能第一时间回复…

Acme PHP - Let‘s Encrypt

Lets Encrypt是一个于2015年三季度推出的数字证书认证机构,旨在以自动化流程消除手动创建和安装证书的复杂流程,并推广使万维网服务器的加密连接无所不在,为安全网站提供免费的SSL/TLS证书。 使用PHP来更新证书: Acme PHP | Rob…

【Linux清空显存占用】Linux 系统中清理 GPU 显存

操作指令 # 查看NVIDIA GPU状态和进程 nvidia-smi # 查找所有包含"python"的进程 ps -ef grep python # 强制结束进程号为3023的进程 kill -9 3023截图演示 在 Linux 系统中清理 GPU 显存可以采用以下方法: 1. 终止特定进程(常用方法&#x…

【网络】网络抓包与协议分析

网络抓包与协议分析 一. 以太网帧格式分析 这是以太网数据帧的基本格式,包含目的地址(6 Byte)、源地址(6 Byte)、类型(2 Byte)、数据(46~1500 Byte)、FCS(4 Byte)。 Mac 地址类型 分为单播地址、组播地址、广播地址。 单播地址:是指第一个字节的最低位…

IC脚本之perl

Perl 是一种功能丰富的计算机程序语言,运行在超过100种计算机平台上。IC flow 的 流传的古老版本大多是也是使用这种语言,这里会对Perl的常用知识点进行总结。 Note: 所有的语句必须以 “ ;”结尾;所有的数据必须先定义才可以使…

MEMS硅麦克风应用电子烟雾化产业稳步爬升,耐高温、 防油、防酸、防腐蚀等性能优势和可实现自动化贴片及极高的一致性等特性使其必将成为主流

全球范围内,电子烟行业正处于快速发展的阶段。随着消费者健康意识的提升和对传统烟草制品替代品需求的增加,电子烟市场获得了显著的增长。然而,伴随而来的监管挑战和消费者期待的变化,也促使行业不断进行技术创新和产品优化。特别…