VSCode 多工程联合调试

在 Visual Studio Code (VSCode) 中联合调试两个 C++ 工程,其中一个是进程,另一个是依赖库,你可以通过设置调试配置文件和使用 launch.json 来实现。

假设你的工程结构如下:

  • ProjectA: 包含主进程(可执行文件)。
  • ProjectB: 包含库文件,ProjectA 依赖它。

步骤 1:配置 tasks.json

首先,确保你能够编译这两个项目。你需要在 tasks.json 文件中设置编译任务。

例如,对于 ProjectAProjectB,你可以有类似的配置:

json 复制代码
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "build ProjectA",
      "type": "shell",
      "command": "g++",
      "args": [
        "-g", "projectA_main.cpp", "-o", "projectA_executable", "-L./projectB", "-lprojectB"
      ],
      "group": {
        "kind": "build",
        "isDefault": true
      }
    },
    {
      "label": "build ProjectB",
      "type": "shell",
      "command": "g++",
      "args": [
        "-g", "projectB_lib.cpp", "-o", "libprojectB.a", "-c"
      ],
      "group": {
        "kind": "build",
        "isDefault": true
      }
    }
  ]
}

步骤 2:配置 launch.json

接下来,配置 launch.json 来设置联合调试。你需要为 ProjectA(进程)创建调试配置,并确保它在启动时能够加载 ProjectB 的库。

json 复制代码
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "Debug ProjectA with ProjectB",
      "type": "cppdbg",
      "request": "launch",
      "program": "${workspaceFolder}/projectA_executable", // 指向 ProjectA 的可执行文件
      "args": [],
      "stopAtEntry": false,
      "cwd": "${workspaceFolder}",
      "environment": [],
      "externalConsole": false,
      "MIMode": "gdb",
      "setupCommands": [
        {
          "description": "Enable pretty-printing for gdb",
          "text": "-enable-pretty-printing",
          "ignoreFailures": true
        }
      ],
      "miDebuggerPath": "/usr/bin/gdb",
      "preLaunchTask": "build ProjectA",  // 编译 ProjectA
      "postDebugTask": "",
      "logging": {
        "moduleLoad": false,
        "programOutput": true,
        "engineLogging": false,
        "exceptions": true
      },
      "windows": {
        "MIMode": "gdb",
        "miDebuggerPath": "C:/path/to/gdb.exe"
      }
    }
  ]
}

步骤 3:设置调试依赖库

如果 ProjectA 依赖于 ProjectB 库,你可以通过 launch.json 设置 LD_LIBRARY_PATH 或其他环境变量来确保调试时可以找到 ProjectB 的库。

例如,在 launch.json 中设置 environment 字段:

json 复制代码
"environment": [
  {
    "name": "LD_LIBRARY_PATH",
    "value": "${workspaceFolder}/projectB"
  }
]

步骤 4:启动联合调试

  1. 在 VSCode 中选择调试配置 "Debug ProjectA with ProjectB"。
  2. 使用 F5 或点击调试按钮开始调试。VSCode 会自动构建并启动 ProjectA,并且会连接到 ProjectB 的库,开始联合调试。

这样,你就可以同时调试 ProjectA 的进程和 ProjectB 的库了。

相关推荐
wind瑞22 分钟前
IntelliJ IDEA插件开发-代码补全插件入门开发
java·ide·intellij-idea
阿乾之铭1 小时前
IDEA中创建多模块项目步骤
java·ide·intellij-idea
哑巴湖小水怪3 小时前
WPS宏编辑器开发,单元格内容变更自动触发事件
java·编辑器·wps
Dreams°12314 小时前
【ECMAScript标准规范】
前端·vscode·前端框架·ecmascript
Byyyi耀20 小时前
Jupyter notebook如何加载torch环境
ide·python·jupyter
----云烟----21 小时前
Eclipse下载与安装
java·ide·eclipse
哟哟耶耶1 天前
vscode-相关自用插件(倒计时,时间显示,编码对齐,css等编码颜色,简体中文,git提交相关,vue项目)
ide·vscode·编辑器
羊小猪~~1 天前
前端入门一之ES6--面向对象、够着函数和原型、继承、ES5新增方法、函数进阶、严格模式、高阶函数、闭包
开发语言·前端·javascript·css·vscode·html·es6
Byyyi耀1 天前
更改 Jupyter Notebook 中文件的存放位置
ide·python·jupyter