vscode利用cmake调试

本文介绍如何在VSCode中配置CMake插件进行C/C++项目的debug调试,包括launch.json文件配置和解决debug提示问题的方法,以及如何更新cmake版本。

vscode配置cmake插件,进行debug

配置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",
            // Resolved by CMake Tools:
            "program": "${command:cmake.launchTargetPath}",
            "args": [],
            "stopAtEntry": false,
            "cwd": "${workspaceFolder}",
            "environment": [],
            "externalConsole": true,
            "MIMode": "gdb",
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                }
            ]
        }
    ]
}

运行vscode左下角的角标,如下

依次运行,cmake,build,debug

其中将[all]切换为想要进行debug的可执行文件

点击debug(虫子型图标),会提示`Target debugging is no longer supported with the legacy driver`

解决方法:

查看自己的cmake版本,ubuntu16.04 默认安装的cmake为3.5.1版本

vscode的cmake插件要求cmake>=3.7.1

更新自己的cmake,重新打开vscode,依次运行,cmake,build,debug即可

 

附cmake更新教程,转自

1. 卸载已经安装的旧版的CMake[非必需]

apt-get autoremove cmake

2. 文件下载解压:

wget https://cmake.org/files/v3.9/cmake-3.9.1-Linux-x86_64.tar.gz

解压:

tar zxvf cmake-3.9.1-Linux-x86_64.tar.gz

查看解压后目录:

tree -L 2 cmake-3.9.1-Linux-x86_64
cmake-3.9.1-Linux-x86_64
├── bin
│   ├── ccmake
│   ├── cmake
│   ├── cmake-gui
│   ├── cpack
│   └── ctest
├── doc
│   └── cmake
├── man
│   ├── man1
│   └── man7
└── share
    ├── aclocal
    ├── applications
    ├── cmake-3.9
    ├── icons
    └── mime

12 directories, 5 files

bin下面有各种cmake家族的产品程序.

3. 创建软链接

注: 文件路径是可以指定的, 一般选择在/opt 或 /usr 路径下, 这里选择/opt

mv cmake-3.9.1-Linux-x86_64 /opt/cmake-3.9.1
ln -sf /opt/cmake-3.9.1/bin/*  /usr/bin/ 

然后执行命令检查一下:

>>>cmake --version
cmake version 3.9.1

CMake suite maintained and supported by Kitware (kitware.com/cmake).
>>>
>>>cmake-gui

OK。现在cmake最新版本安装成功。 
cmake图形化界面

CMake的官方书籍很贵,并且总是晚于实际最新版本,如果想看最新的文档,建议参考: 
https://cmake.org/cmake-tutorial/

参考: 
ubuntu下cmake的GUI界面 
Ubuntu下安装最新版本的CMake

 

### 配置 VSCode 使用 CMake 调试 C++ 项目 要在 VSCode 中设置 C++ 项目并使用 CMake 进行调试,可以按照以下方法操作: #### 插件安装 确保已安装必要的扩展插件,包括但不限于 `C/C++` 和 `CMake Tools` 扩展。这些插件提供了对 C++ 开发的支持以及通过 CMake 自动生成构建系统的功能[^2]。 #### 初始化工作区 1. **创建项目结构** 创建一个标准的 C++ 项目目录结构,通常包含源码文件夹(如 `src`)、头文件夹(如 `include`),并在根目录下放置 `CMakeLists.txt` 文件用于定义项目的构建逻辑[^5]。 2. **配置 CMakeLists.txt** 编辑 `CMakeLists.txt` 来指定目标、链接库和其他编译参数。例如: ```cmake cmake_minimum_required(VERSION 3.10) project(MyProject) set(CMAKE_CXX_STANDARD 17) add_executable(my_app main.cpp other_file.cpp) target_include_directories(my_app PRIVATE ${PROJECT_SOURCE_DIR}/include) ``` #### 设置开发环境 1. **初始化 CMake 工具链** 在 VSCode 中打开终端,执行命令 `cmake --version` 检查是否已经安装了 CMake。如果没有,则需先完成安装[^4]。 2. **选择工具链和生成器** 利用 `CMake Tools` 提供的功能,在状态栏上点击提示信息以选择合适的编译器套件(Toolchain)与生成器(Generator)。这一步骤对于跨平台开发尤为重要[^1]。 3. **自动检测或手动添加编译器路径** 如果发现未正确识别到本地 GCC 或 Clang 等编译器位置,可以通过修改用户设置 JSON 添加如下字段: ```json { "cmake.configureSettings": { "CMAKE_C_COMPILER": "/usr/bin/gcc", "CMAKE_CXX_COMPILER": "/usr/bin/g++" } } ``` 此外还可以调整其他高级选项满足特定需求[^3]。 #### 启动调试会话 利用左侧活动栏上的“运行和调试”视图或者快捷键 F5 可快速触发调试流程。在此之前应确认 launch.json 是否由系统自动生成完毕;如果缺失则重新加载窗口让 CMake Tools 自动补全相关内容。 --- ### 示例代码片段展示简单的单步调试场景 假设存在这样一个简单程序作为起点: ```cpp #include <iostream> int main() { int a = 1; int b = 2; std::cout << "Sum is: " << (a+b) << "\n"; return 0; } ``` 当断点设于打印语句前时,可通过观察变量面板实时追踪局部变量值变化情况验证其计算准确性。 ---
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值