ROS2节点使用vscode debug

Ubuntn22.04 6 + ROS2 Humble

首先安装 gdbserver

sudo apt-get -y install gdbserver

创建工作空间及src文件夹 ws/src,用colcon编译(ros1 是 catkin,ros2是colcon)

创建功能包

ros2 pkg create your_package_name

source setup.bash文件,与ros1不同,ros2的setup.bash文件在工作空间的install文件夹下

source install/setup.bash

修改功能包的cmakelist.txt,加入

set(CMAKE_BUILD_TYPE Debug)

可以打断点暂停

# find dependencies
find_package(ament_cmake REQUIRED)
find_package(rclcpp REQUIRED)
find_package(pcl_ros REQUIRED)
find_package(pcl_conversions REQUIRED)
find_package(sensor_msgs REQUIRED)

加入相关的依赖项

# 生成可执行文件
add_executable (executable_file_name src/your_file_name.cpp)

# 配置可执行文件的依赖项
ament_target_dependencies(executable_file_name 
  rclcpp 
  pcl_ros 
  pcl_conversions 
  sensor_msgs)  

# 将可执行文件写入路径
install(TARGETS
  executable_file_name
  DESTINATION lib/${PROJECT_NAME})  

运行gdbserver

ros2 run --prefix 'gdbserver localhost:3000' package_name executable_name

用vscode打开工作空间

创建一个launch.json文件

写入如下内容

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "C++ Debugger",
            "request": "launch",
            "type": "cppdbg",
            "miDebuggerServerAddress": "localhost:3000",
            "cwd": "/",
            "program": "你的可执行文件的路径"
        }
    ]
}

然后就可以打上断点debug了

### 配置 VSCode 进行 ROS 项目的调试 要在 VSCode 中设置 ROS 调试配置,需确保开发环境中已安装必要的插件并完成基本的环境搭建。通过特定的方法可以实现对 launch 文件以及单个节点的有效调试。 #### 安装必备工具与扩展 为了使代码提示和调试更加便捷,在 VSCode 中应安装 `roscatkin-tools` 和 C++ 扩展[^2]。这些工具不仅有助于提高编码效率还能简化构建流程。 #### 创建 Catkin 工作空间及初始化 建立一个新的工作目录用于存放 ROS 包,并执行如下命令来创建一个标准结构的工作区: ```bash mkdir -p catkin_ws/src && cd catkin_ws catkin_make source devel/setup.bash code . ``` 此过程将准备一个适合于后续操作的基础框架。 #### 启用编译指令 JSON 输出 为了让编辑器更好地理解项目中的依赖关系和其他元数据信息,可以通过运行以下命令生成 `compile_commands.json` 文件,该文件位于 ROS 工作空间下的 build 文件夹中: ```bash catkin config --cmake-args -DCMAKE_EXPORT_COMPILE_COMMANDS=ON ``` 这一步骤对于集成高级特性至关重要[^3]。 #### 设置 Launch 或 Attach 调试模式 根据需求选择合适的调试方式——如果目标是对整个启动序列进行分析,则采用 **ROS:Launch**;而当关注点集中在一个具体的进程中时,则推荐使用 **ROS:Attach** 来附加到指定进程上进行深入探究[^1]。 #### 编写 `.vscode/launch.json` 最后,在项目根目录下新建或修改 `.vscode/launch.json` 文件以定义具体要使用的调试参数。这里提供了一个简单的例子作为参考: ```json { "version": "0.2.0", "configurations": [ { "name": "(gdb) Launch", "type": "cppdbg", "request": "launch", "program": "${workspaceFolder}/devel/lib/${your_package_name}/${node_executable}", "args": [], "stopAtEntry": false, "cwd": "${workspaceFolder}", "environment": [], "externalConsole": true, "MIMode": "gdb" } ] } ``` 请注意替换 `${your_package_name}` 及 `${node_executable}` 占位符为实际值以便正确指向待调试的目标程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值