【VSCode-C++-ROS-DEBUG】在vscode中对ros的C++代码debug出现的断点无效的问题解决

本文探讨了在ROS开发中遇到的断点在Debug模式下无效的问题,指出原因是未在编译时设置debug模式。解决方案是通过`catkin_makeDCMAKE_BUILD_TYPE=debug`或在VSCode内设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

注意:本文只针对设置的断点在debug模式下无效的问题,不介绍怎么设置。如何设置见:

Debug ROS Nodes-Github.com

所有设置按上述介绍走,但是就直接忽视断点。
在找解决方法的时候看到了油管上的这个视频:

Visual Studio Code ROS Extension - Season 1 Episode 6 - Debugging C++

视频本身没有提供解决方法,但是在评论区有。原因在于,编译的时候没有设置debug模式。正确的做法是在命令行输入:

catkin_make -DCMAKE_BUILD_TYPE=debug

或者在vscode里面编译,这个在其他文章有说,这里略。
完事。

### 配置VSCode进行ROS调试环境 #### 安装必要的扩展 为了使Visual Studio Code (VSCode)能够支持ROS开发,在VSCode中需安装特定的插件[^1]。 #### 创建并初始化Catkin工作区 创建一个新的工作目录用于存放ROS项目,并通过`catkin_make`来构建此工作空间。这一步骤对于确保后续操作顺利至关重要: ```bash mkdir -p catkin_ws/src cd catkin_ws catkin_make source devel/setup.bash code . ``` 上述命令序列不仅建立了新的Catkin工作区,还启动了VSCode编辑器实例[^3]。 #### 自动生成配置文件 一旦安装了ROS相关插件之后,VSCode将会自动检测到当前为一个Catkin项目,并自动生成`.vscode/`文件夹及其内部包含的关键JSON配置文件如`c_cpp_properties.json`和`settings.json`,这些文件有助于IDE更好地理解项目的结构以及提供更佳的功能支持[^2]。 #### 设置编译指令以生成compile_commands.json 为了让C/C++语言服务器能正确解析源码中的宏定义和其他预处理器指示符,通常建议执行如下命令以便于在构建过程中生成`compile_commands.json`文件,该文件位于ROS工作空间下的`build`子目录内: ```bash catkin build --cmake-args -DCMAKE_EXPORT_COMPILE_COMMANDS=ON ``` 这条命令的作用是在每次构建时都更新或创建所需的编译信息文件[^4]。 #### 开始编写代码与调试准备 完成以上步骤后,即可开始向新建立的工作区内添加自己的ROS节点或其他组件;同时也可以利用VSCode内置的强大工具链来进行断点设置、单步执行等功能实现高效便捷的应用程序测试过程[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值