VSCode 配置 ROS2 Launch 调试环境(Attach 方式)

VSCode 配置 ROS2 Launch 调试环境(Attach 方式)

适用环境:

Ubuntu + ROS2 Foxy + colcon + VSCode + C++(rclcpp)

推荐方式:使用 ros2 launch 启动整个系统,再 attach 调试单个节点

参考链接:vscode中使用断点 调试ROS功能包(一)

在 vscode 中断点调试 ROS2 C++ 的办法

1. 安装ROS2插件

2. 创建.vscode配置文件

launch.json

bash 复制代码
{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "Attach to search_manager",
            "type": "cppdbg",
            "request": "attach",
            "program": "${workspaceFolder}/install/test_node/lib/test_node/test_node",
            "processId": "${command:pickProcess}",
            "MIMode": "gdb",
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                }
            ]
        }
    ]
}

settings.json

bash 复制代码
{
    "ROS2.distro": "foxy",
    "ROS2.rosSetupScript": "${workspaceFolder}/install/setup.bash",
    "files.associations": {
        "*.hpp": "cpp",
        "*.h": "cpp",
        "*.c": "cpp",
        "*.cpp": "cpp"
    }
}

tasks.json

bash 复制代码
{
    "version": "2.0.0",
    "tasks": [
        {
            "label": "colcon build (Debug)",
            "type": "shell",
            "command": "/bin/bash",
            "args": [
                "-c",
                "source /opt/ros/foxy/setup.bash && source ${workspaceFolder}/install/setup.bash && colcon build --cmake-args -DCMAKE_BUILD_TYPE=Debug --symlink-install"
            ],
            "group": {
                "kind": "build",
                "isDefault": true
            },
            "presentation": {
                "reveal": "always"
            },
            "problemMatcher": []
        }
    ]
}

3. 编译

在 VSCode 中执行快捷键Ctrl + Shift + B,选择colcon build (Debug)

4. 运行

  • 终端启动 ROS2 Launch

⚠️ 必须在Linux终端启动,而不是 VSCode launch

bash 复制代码
source /opt/ros/foxy/setup.bash
source install/setup.bash
ros2 launch test_node test.launch.py
  • 打开源码设置断点

  • 启动调试 : VScode终端按下F5,选择需要调试的进程即可

问题1:launch.json,settings.json,tasks.json的区别是什么?

1. tasks.json ------ 负责编译

相当于在终端输入:

bash 复制代码
source /opt/ros/foxy/setup.bash
colcon build --cmake-args -DCMAKE_BUILD_TYPE=Debug
问题 解决方式
每次手动敲 build 命令 Ctrl+Shift+B 一键编译
忘记 Debug 编译 强制 Debug
环境变量没加载 在 command 里 source

2. launch.json ------ 负责调试器行为

  • 使用 gdb
  • 附加到某个运行中的进程
  • 让断点生效
问题 解决方式
断点不生效 Debug 模式 + gdb
多节点系统不好直接启动 用 attach
launch 参数丢失 终端启动 + attach

3. settings.json ------ 负责编辑器行为

  • 指定 ROS2 发行版(foxy)
  • 指定 setup.bash 路径
  • 帮助 IntelliSense 识别头文件
  • 控制 C++ 代码提示
问题 解决方式
找不到 rclcpp 头文件 设置 ROS2.distro
代码红线但能编译 配置 include
智能提示失效 指定 cmake provider

4. 三者关系图

复制代码
                ┌──────────────┐
                │ settings.json│
                │ (代码提示)    │
                └──────┬───────┘
                       │
                       ▼
修改代码 ──→ Ctrl+Shift+B ──→ tasks.json ──→ colcon build
                       │
                       ▼
终端 ros2 launch
                       │
                       ▼
F5 ──→ launch.json ──→ gdb attach

5. 角色分工

文件 职责 是否必须
tasks.json 编译 ✅ 必须
launch.json 调试 ✅ 必须
settings.json 代码提示 ⚠ 建议
相关推荐
VidDown6 天前
VidDown 工具站:免费、本地优先的开发者工具箱
javascript·编辑器·音视频·视频编解码·视频
摇滚侠6 天前
IDEA 创建 Java 项目 手动整合 SSM 框架
java·ide·intellij-idea
霸道流氓气质6 天前
Trae IDE 新手入门指南
ide
VidDown6 天前
显卡处理视频技术详解:从硬解码到 NVENC,GPU 如何让视频处理起飞?
javascript·编辑器·音视频·视频编解码·视频
夜猫逐梦6 天前
【UE基础】03.蓝图与编辑器工作流
编辑器·ue·蓝图·ue编辑器
VidDown6 天前
视频帧率技术详解:从 24fps 到 120fps,帧率如何影响你的观看体验?
网络·网络协议·编辑器·音视频·视频编解码·视频
爱就是恒久忍耐6 天前
VSCode里如何比较2个branch
ide·vscode·编辑器
意法半导体STM326 天前
【官方原创】如何为STM32CubeMX2配置Visual Studio Code配置方案
vscode·stm32·单片机·嵌入式硬件·策略模式·stm32cubemx·嵌入式开发
bloglin999996 天前
vscode中可视化的合并分支,在“合并编辑器中解析”中“与基线进行比较”是什么意思
ide·vscode·编辑器
终将老去的穷苦程序员6 天前
IntelliJ IDEA 的安装教程
java·ide·intellij-idea