ROS 1 VSCode 调试方法
ROS 1 的代码中,如果 c++ 部分崩溃,直接 gdb 并不容易: How to Roslaunch Nodes in Valgrind or GDB。
比较好的办法是在 .launch 中对应的<node />添加launch-prefix="gdb -ex run --args",如
<node name="listener" pkg="examples" type="listener" output="screen" launch-prefix="gdb -ex run --args" /> 
如果直接在命令行调试比较难受,则可以用 GDB Server 远程(参考 How to attach to remote gdb with vscode?)
首先把launch-prefix改为launch-prefix="gdbserver localhost:10000"。
然后在 .vscode/launch.json 添加调试配置
{
    // Use IntelliSense to learn about possible attributes.
    // Hover to view descriptions of existing attributes.
    // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "Debug listener",
            "type": "cppdbg",
            "request": "launch",
            "program": "/path/to/listener", // for loading symbols from running program
            "cwd": "${workspaceFolder}",
            // if you want to connect at entry point (requires remote program to start paused)
            "stopAtEntry": false,
            "stopAtConnect": false,
            "MIMode": "gdb",
            "miDebuggerPath": "/usr/bin/gdb",
            "miDebuggerServerAddress": "localhost:10000",
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true,
                }
            ]
        }
    ]
}
Python
Python 代码要调试的话也是类似,添加一个python3 -m debugpy --listen 5678的前缀即可(需要安装 debugpy)。在 VSCode 这边,.vscode/launch.json 的内容是
{
    // Use IntelliSense to learn about possible attributes.
    // Hover to view descriptions of existing attributes.
    // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "Python Debugger: Remote Attach",
            "type": "debugpy",
            "request": "attach",
            "connect": {
                "host": "localhost",
                "port": 5678
            },
            "justMyCode": false,
            "pathMappings": [
                {
                    "localRoot": "${workspaceFolder}",
                    "remoteRoot": "."
                }
            ]
        }
    ]
}