vscode 调试手册

1、编写cmakelist.txt

cmake_minimum_required (VERSION 2.8.7)
project (interface)
set(VSOMEIP_LIBRARIES )
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++14 -g")
FILE(GLOB base_files "${CMAKE_SOURCE_DIR}/src/*cpp")
add_executable (interface ${base_files})
set(EXECUTABLE_OUTPUT_PATH ${CMAKE_BINARY_DIR}/../bin)

2、编译可执行文件

mkdir build
cd build
cmake ..
make

3、编写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": "(gdb) Launch",
            "type": "cppdbg",
            "request": "launch",
            // "program": "此处填写需要调试的exe二进制文件",
            "program": "${workspaceFolder}/tbox11/projects/interface/bin/interface",
            "args": [],
            "stopAtEntry": false,
            "cwd": "${fileDirname}",
            "environment": [],
            "externalConsole": false,
            "MIMode": "gdb",
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                },
                {
                    "description": "Set Disassembly Flavor to Intel",
                    "text": "-gdb-set disassembly-flavor intel",
                    "ignoreFailures": true
                }
            ]
        }

    ]
}

4、按F5即可调试

参数详解


### 详解

- **version**: 配置文件的版本,目前通常为 `0.2.0`。- **configurations**: 这是一个数组,包含多个调试配置。每个配置都是一个 JSON 对象。#### 配置项详解

1. **name**: 配置的名称,可以是任意字符串,方便你在 VS Code 中识别不同的配置。

2. **type**: 调试器的类型,对于 C++ 来说通常是 `cppdbg`。

3. **request**: 调试请求的类型,可以是 `launch`(启动程序)或 `attach`(附加到正在运行的程序)。

4. **program**: 要调试的程序的路径。可以使用 VS Code 的变量,如 `${workspaceFolder}` 代表当前工作区的根目录。

5. **args**: 传递给程序的命令行参数,是一个字符串数组。

6. **stopAtEntry**: 是否在程序入口处停止,布尔值。

7. **cwd**: 调试时的工作目录,通常设置为 `${workspaceFolder}`。

8. **environment**: 环境变量设置,是一个对象数组,每个对象包含 `name` 和 `value` 两个属性。

9. **externalConsole**: 是否使用外部控制台,布尔值。设置为 `true` 会在外部控制台中运行程序。

10. **MIMode**: 调试器的模式,对于 GDB 调试器,设置为 `gdb`。

11. **miDebuggerPath**: GDB 调试器的路径。

12. **setupCommands**: 调试器启动时执行的命令数组。这里的例子启用了 GDB 的 pretty-printing 功能。

13. **preLaunchTask**: 调试前要执行的任务,通常是编译任务。这个任务需要在 `tasks.json` 文件中定义。

14. **logging**: 日志配置,可以控制不同类型的日志输出。
    - `moduleLoad`: 是否记录模块加载信息。
    - `programOutput`: 是否记录程序输出。
    - `trace`: 是否记录调试器的跟踪信息。
    - `engineLogging`: 是否记录调试器引擎的日志。

15. **internalConsoleOptions**: 内部控制台选项,控制调试时内部控制台的行为。
    - `openOnSessionStart`: 在调试会话开始时打开内部控制台。
    - `neverOpen`: 永不打开内部控制台。
    - `openOnFirstSessionStart`: 仅在第一次调试会话开始时打开内部控制台。

### 总结

`launch.json` 文件是 VS Code 中配置调试环境的重要文件。通过合理配置,可以大大提高调试效率和体验。希望以上示例和详解能帮助你更好地理解和使用 `launch.json` 文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值