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 的库了。

相关推荐
山峰哥5 天前
吃透 SQL 优化:告别慢查询,解锁数据库高性能
服务器·数据库·sql·oracle·性能优化·编辑器
Diligently_6 天前
idea 中vm option 配置
java·ide·intellij-idea
holeer6 天前
【V1.0】Typora 中的 HTML 支持|软件文档自翻译
前端·编辑器·html·typora·web·markdown·文档
我命由我123456 天前
在 Android Studio 中,新建 AIDL 文件按钮是灰色
android·ide·android studio·安卓·android jetpack·android-studio·android runtime
硬汉嵌入式6 天前
Vim 9.2版本正式发布
编辑器·vim
Hello World . .6 天前
Linux:线程间通信
linux·开发语言·vscode
AC赳赳老秦6 天前
云原生AI故障排查新趋势:利用DeepSeek实现高效定位部署报错与性能瓶颈
ide·人工智能·python·云原生·prometheus·ai-native·deepseek
被制作时长两年半的个人练习生6 天前
claude code for vscode 配置 qwen3.5
ide·vscode·claude code·qwen3.5
圣心6 天前
Visual Studio Code 中的 AI 智能操作
ide·人工智能·vscode
吹牛不交税6 天前
关于vscode左侧资源管理器目录层级疑似异常的问题
ide·vscode·编辑器