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` 文件。