vscode工程调试

一、没有CMake文件

目录结构:

建一个工程目录,目录结构如下:

.
├── mytest
├── mytest.cpp
├── mytest.exe
└── .vscode
    ├── c_cpp_properties.json
    ├── extensions.json
    ├── launch.json
    ├── settings.json
    └── tasks.json

c_cpp_properties.json:

{
    "configurations": [
        {
            "name": "Linux",
            "includePath": [
                "${workspaceFolder}/**"
            ],
            "defines": [],
            "compilerPath": "/usr/bin/gcc",
            "cStandard": "c11",
            "cppStandard": "c++17",
            "intelliSenseMode": "gcc-x64"
            // "compileCommands": "${workspaceFolder}/compile_commands.json",
            // "configurationProvider": "ms-vscode.cmake-tools"
        }
    ],
    "version": 4
}

 launch.json

{
	"version": "0.2.0",
	"configurations": [
		{
			"name": "Debug C/C++",
			"type": "cppdbg",
			"request": "launch",
			"program": "${workspaceFolder}/${fileBasenameNoExtension}",
			"args": [],
			"stopAtEntry": false,
			"cwd": "${workspaceFolder}",
			"environment": [],
			"externalConsole": false,
			"MIMode": "gdb",
			"miDebuggerPath": "/usr/bin/gdb",
			"setupCommands": [{
				"description": "Enable pretty-printing for gdb",
				"text": "-enable-pretty-printing",
				"ignoreFailures": false
			}],
			"preLaunchTask": "build & debug file"
		}
	]
}

task.json

{
	"version": "2.0.0",
	"tasks": [
        {
            "label": "build & debug file",
            "type": "shell",
            "command": "g++",
            "args": [
                "-g",
                "-o",
                "${fileBasenameNoExtension}",
                "${file}"
            ],
            "group": {
                "kind": "build",
                "isDefault": true
            },
            "problemMatcher": "$gcc"
        }
    ]
}

 mytest.cpp

#include<iostream>
#include<stdio.h> 
#include<vector>
#include<algorithm>
#include<string>
#include<time.h>
using namespace std;

#define NUM 10000000000

  

long long fun(long long n)
{
    long long t =1;
    for(int i=1; i<=n; i++)
    {
        t = t * n ;
        if(t > NUM)
            t = t % NUM;
    }
    return t;
}

int main(int argc, const char **argv ) 
{
   
    int maxNum = 1000;
    long long ret=0;

    for(int i=1;i<=maxNum;i++)
    {
        if(i % 10 == 0)   
            continue;
        ret += fun(i); 
        if(ret> NUM)
            ret = ret % NUM;
    }

    cout << "(1^1+2^2+...+1000^1000) %1000000000 = "<< ret<<endl;
   
    return 0;
}

 设置好后进行调试即可。

二、简单CMake

目录结构:

建一个工程目录,目录结构如下

.
├── build
├── CMakeLists.txt
├── code
│   ├── inc
│   └── src
└── .vscode
    ├── c_cpp_properties.json
    ├── extensions.json
    ├── launch.json
    ├── settings.json
    └── tasks.json

c_cpp_properties.json

{
    "configurations": [
        {
            "name": "Linux",
            "includePath": [
                "${workspaceFolder}/**"
            ],
            "defines": [],
            "compilerPath": "/usr/bin/gcc",
            "cStandard": "c11",
            "cppStandard": "c++17",
            "intelliSenseMode": "gcc-x64"
            // "compileCommands": "${workspaceFolder}/compile_commands.json",
            // "configurationProvider": "ms-vscode.cmake-tools"
        }
    ],
    "version": 4
}

launch.json

{
	"version": "0.2.0",
	"configurations": [
		{
			"name": "Debug C/C++",
			"type": "cppdbg",
			"request": "launch",
			"program": "${workspaceFolder}/build/last",
			// "program": "${workspaceFolder}\\${fileBasenameNoExtension}.exe",
			"args": [],
			"stopAtEntry": false,
			"cwd": "${workspaceFolder}",
			"environment": [],
			"externalConsole": false,
			"MIMode": "gdb",
			"miDebuggerPath": "/usr/bin/gdb",
			"setupCommands": [{
				"description": "Enable pretty-printing for gdb",
				"text": "-enable-pretty-printing",
				"ignoreFailures": false
			}],
			"preLaunchTask": "Build"
		}
	]
}

task.json

{
    "version":"2.0.0",
    "options":
    {                             
        "cwd": "${workspaceFolder}/build"    // 调用该task.json 任务时,首先进入到 build目录下
    },
    "tasks": [
        { 
            "type": "shell",
            "label": "cmake",          // 构造  "cmake .. " 命令
            "command":"cmake",
            "args": [
                ".."
            ]

        },
        {
            "type": "shell",
            "label": "make",       // 使用make命令来编译,当前window下使用到了mingw64 下的mingw32-make.exe 来触发
            "group": {
                "kind": "build",
                "isDefault": true
            },
            "command":"make"
            // "command":"mingw32-make.exe"
        },
        {
            "label": "Build",    // launch.json 文件中调用的 "preLaunchTask": "Build",会调用到此Task
            "dependsOn":[        // 该task下依赖其他两个任务 cmake 、make 任务
                "cmake",
                "make"
            ]

        }

    ]
}

inc下文件swap.h:

#ifndef _SWAP_H_
#define _SWAP_H_

void swap(int &a, int &b)
{
    int temp;
    temp = a;
    a = b;
    b = temp;
}

#endif

src文件main.cpp

#include <iostream>
#include "swap.h"
using namespace std;

int main(int argc, const char *argv[])
{
	int a = 10;
	int b = 20;
	cout <<"Before:" << a << ","<< b << endl;
	swap(a, b);
	cout <<"After:" << a << ","<< b << endl;
	return 0;
}

CMakeLists.txt

cmake_minimum_required(VERSION 3.11)
project(MY_CMAKE)

set(CMAKE_CXX_STANDARD 14)

# 显示指定使用的C++编译器 
set(CMAKE_CXX_COMPILER "g++")
set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g")

# add_executable(mycmake mycmake.cpp)

 
#Bring the headers, such as Student.h into the project
include_directories(code/inc)
 
#Can manually add the sources using the set command as follows:
# set(SOURCES code/src/mycmake.cpp code/src/mycmake.cpp)
 
#However, the file(GLOB...) allows for wildcard additions:
file(GLOB SOURCES "code/src/*.cpp")

# 指定生成目标
add_executable(last ${SOURCES})

构建工程即可编译

三、VSCode+CMake+gtest

下载gooletest,解压,进入目录,新建build,进入build新建gtest,执行cmake ..和make,退到build目录,再执行cmake..和make

建立工程:

创建一个工程目录,目录结构如下:

.
├── build
├── CMakeLists.txt
├── googletest-release-1.8.1
│   ├── appveyor.yml
│   ├── build
│   ├── BUILD.bazel
│   ├── ci
│   ├── CMakeLists.txt
│   ├── configure.ac
│   ├── CONTRIBUTING.md
│   ├── .gitignore
│   ├── googlemock
│   ├── googletest
│   ├── LICENSE
│   ├── Makefile.am
│   ├── README.md
│   ├── .travis.yml
│   └── WORKSPACE
├── googletest-release-1.8.1.zip
├── main.cpp
└── test.cpp

 

CMakeLists.txt

cmake_minimum_required(VERSION 2.6)
project(basic_test)

################################
# GTest
################################
ADD_SUBDIRECTORY (googletest-release-1.8.1)
enable_testing()
include_directories(${gtest_SOURCE_DIR}/include ${gtest_SOURCE_DIR})

################################
# Unit Tests
################################
# Add test cpp file
add_executable( runUnitTests test.cpp main.cpp)
# Link test executable against gtest & gtest_main
target_link_libraries(runUnitTests gtest gtest_main)
add_test( runUnitTests runUnitTests )

 

main函数:

#include "gtest/gtest.h"
 
int main(int argc, char **argv)
{
    testing::InitGoogleTest(&argc, argv);
    return RUN_ALL_TESTS();
}

test.cpp

#include <iostream>

#include "gtest/gtest.h"

TEST(sample_test_case, sample_test)
{
    EXPECT_EQ(1, 1);
}

 

进入build目录,执行

cmake ..
make

生成执行文件

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
引用\[1\]:在Linux系统中使用VSCode编译调试C++代码的过程可以通过以下几篇文章进行学习和总结。首先是详解C/C++代码的预处理、编译、汇编、链接全过程的文章,然后是关于在Linux环境下使用VSCode调试简单C++代码的文章,最后是关于在Linux环境下使用VSCode调试CMake工程的文章。\[1\] 引用\[2\]:在VSCode调试代码的过程可以通过左侧菜单栏的第四个按钮来创建launch.json文件,并选择相应的配置。在调试过程中,可以使用不同的按钮来控制代码的执行,例如继续按钮用于执行到下一个断点的位置,单步跳过按钮用于执行下一行代码而不进入函数内部,单步调试按钮用于进入函数的内部,单步跳出按钮用于跳出当前调试的函数内部,重启按钮用于重新进行调试,断开连接按钮用于结束调试。\[2\] 引用\[3\]:如果在点击调试之后出现了"调试设置中的Python路径无效"的错误提示,可能是因为没有选择正确的Python解释器环境。可以通过点击左下角的Python interpreter来选择相应的环境。\[3\] 综上所述,要在VSCode调试代码,首先需要创建相应的配置文件,并选择合适的调试按钮来控制代码的执行。如果出现错误提示,需要检查Python解释器环境是否选择正确。 #### 引用[.reference_title] - *1* [VSCode调试C++代码的多种方案](https://blog.csdn.net/hypc9709/article/details/129433484)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [VSCode调试代码的三种方式](https://blog.csdn.net/cloki/article/details/127119973)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [vscode调试代码方法](https://blog.csdn.net/qq_36814762/article/details/121888762)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值