IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> vscode对C++程序进行调试 -> 正文阅读

[开发工具]vscode对C++程序进行调试

调试helloworld

先建立一个文件夹然后在文件夹,创建一个test.cpp 写下一下内容。

# include <iostream>

int main(int argc, char* argv[]){
    
    for(int i = 0 ; i < argc ; i++){
        std::cout << argv[i] << std::endl;
    }

    std::cout << "hello" << std::endl;
    return 0;
}

然后再写一个最简单的CMakeLists 内容如下:

cmake_minimum_required(VERSION 3.2)
project(hello)
set(CMAKE_BUILD_TYPE DEBUG)

add_executable(hello test.cpp)

cmake的 CMAKE_BUILD_TYPE 这个一定要大写, 不要问我为什么。。。此处流泪…
之后建立 build 目录 cmake…
然后make
生成了 hello程序了,这个时候就可以开始调试了

首先点击vscode的调试按钮然后生成调试所需要的 launch.json 文件。
这是一个json文件,用于告诉vscode该如何调试这个程序

{
    // 使用 IntelliSense 了解相关属性。 
    // 悬停以查看现有属性的描述。
    // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
    "version": "0.2.0",
    "configurations": [
        {
            "name": "(gdb) 启动",
            "type": "cppdbg",
            "request": "launch",
            "program": "${workspaceFolder}/build/hello",
            "args": ["中国 ", " 是一个伟大的国家"],
            "stopAtEntry": false,
            "cwd": "${fileDirname}",
            "environment": [],
            "externalConsole": false,
            "MIMode": "gdb",
            "setupCommands": [
                {
                    "description": "为 gdb 启用整齐打印",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": true
                }
            ]
        }
    ]
}

修改 program 字段,这个字段用于告诉 vscode该调试哪一个程序。
args 字段用于设置程序的传入参数

然后 运行–》启动调试 就可以进入调试界面了 如图所示:
在这里插入图片描述
现在就可以图形画的进行调试了。

调试先生成可执行程序

刚刚进行调试的时候是现将程序进行编译了,然后才进行的调试。这样子很麻烦,可以直接加一个任务然后让调试前先自动生成。
在 launch.json 中加入 preLaunchTask 选项, pre意思是 前, 就是说在调试前先执行这条命令。
例如在之前的 launch.json 加入: "preLaunchTask": "build"
之后创建一个tasks.json, 创建方法鼠标在vs界面中 右键–> 命令面板–> 选择task 。之后会自动生成模板
将其内容修改为以下内容:

{
    // See https://go.microsoft.com/fwlink/?LinkId=733558
    // for the documentation about the tasks.json format
    "version": "2.0.0",
    "tasks": [
        {
            "label": "build",
            "type": "shell",
            "command": "mkdir build ; cd build; cmake .. ; make",
            "group": "build",
            "presentation": {
                // Reveal the output only if unrecognized errors occur.
                "reveal": "silent"
            },
            // Use the standard MS compiler pattern to detect errors, warnings and infos
            "problemMatcher": "$msCompile"
        }
    ]
}

其中 label 的值一定要和 launch中的 preLaunchTask的值一样
修改 “command” 用于在调试之前先生成代码。
之后点击调试就可以自动进行调试了

参考自: https://code.visualstudio.com/docs/editor/debugging#_launch-configurations

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2022-02-06 14:01:09  更:2022-02-06 14:02:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 22:53:47-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码