栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

win10+gcc+cmake+vscode 的最简demo

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

win10+gcc+cmake+vscode 的最简demo

环境搭建

安装Vscode

安装一些必须插件

安装MinGW, 安装arm_none-eabi-gcc(这个例子中不是必须的,是单片机才需要)

安装CMake

都安装完成后添加至环境变量中

测试能否获取版本

流程梳理

正常未使用cmake的流程: 编写代码--->编写makefile-->make编译-->执行

使用cmake的流程:编写代码--->编写CMakeLists.txt(用于自动生成makefile,可跨平台)--->执行cmake生成makefile(可跨平台)--->make编译--->执行

编写代码

代码目录结构如下 

代码实现

#pragma once
​
#include 
using namespace std;
​
void myprint(void);
​
​
​

#include "test.h"
​
void myprint(void)
{
    std::cout<<"myprint."< 

编写CMakeLists.txt

# 版本要求
cmake_minimum_required(VERSION 3.0)
# 工程名 可以随便命名,暂时没有显示调用,应该是内部调用了,必须要有
project(cmake_test)
# 设置编译器和参数 set()函数就是将 "g++"赋值给CMAKE_CXX_COMPILER
# 实际上类似于 #define CMAKE_CXX_COMPILER "g++"
set(CMAKE_CXX_COMPILER "g++")
set(CMAKE_C_COMPILER "gcc")
set(CMAKE_C_STANDARD 99)
set(CMAKE_CXX_STANDARD 11)
# 添加头文件 ${}表示取值
include_directories(${PROJECT_SOURCE_DIR}/include)
# 设置源文件路径 别名为SRC_DIR
set(SRC_DIR "./main.cpp" "./source/test.cpp")
​
​
# 设置可执行文件的输出路径,如果不存在会创建一个
set(EXECUTABLE_OUTPUT_PATH ${PROJECT_SOURCE_DIR}/bin)
# 设置可执行文件名称,make之后bin目录下会出现demo.exe
add_executable(demo ${SRC_DIR})
​
# 用来显示信息,类似printf
# message("=========test cmake message=============rn" 
#         ${SRC_DIR} "rn"
#         ${EXECUTABLE_OUTPUT_PATH} "rn"
#         ${CMAKE_CXX_COMPILE} "rn"
        
#         ${PROJECT_BINARY_DIR} "rn" # 这个是CMAKE自动创建的
#         ${PROJECT_SOURCE_DIR} "rn" # 这个是CMAKE自动创建的
​
#         ${PROJECT_NAME} "rn"
​
#         "=========test end=============rn" 
#         )

实际上不配置各种.json文件也是可以完成的

新建build文件夹 mkdir build

进入build cd ./build

执行cmake cmake .. 因为CMakeLists.txt在上一级目录,所以需要 ..

但是这里cmake调用了vs studio, 导致没有生成makefile, 所以后面的make也会失败

执行 make 

所以需要切换一下cmake的生成器

cmake -G "MinGW Makefiles" ..

再执行make

此时正常了

执行 demo.exe

使用tasks.json 进行自动操作

创建tasks.json, 可以直接在.vscode下新建,或者如下的操作

ctrl+shift+p 输入 tasks 选择配置任务即可

{
    // See https://go.microsoft.com/fwlink/?linkId=733558
    // for the documentation about the tasks.json format
    "version": "2.0.0",
    "tasks": [
        //! 创建 build 文件夹  即 mkdir build
        {
            "label": "mk_build",    //!< 任务名称
            "type": "shell",
            "command": "mkdir",
            "args": [
                "build",
            ],
            "options": {
                "cwd": "${workspaceFolder}",    //!< 执行在当前目录
            },
        },
        //! 调用 cmake 生成makefile  即  cmake -G "MinGW Makefiles" 
        {
            "label": "cmake",
            "type": "shell",
            "command": "cmake",
            "args": [
                "-G",
                "MinGW Makefiles", //!< 需要指定MinGW Makefiles 否则使用vs studio编译器,不会生成Makefile
                "${workspaceFolder}", //!< CMakeLists.txt的路径
            ],
            "options": {
                "cwd": "${workspaceFolder}/build", //!< 执行路径
            },
            "group": {
                "kind": "build",
                "isDefault": true,
            },
            "dependsOn": [
                "mk_build", //!< 依赖mk_build任务,如果mk_build没执行过,则会先执行mk_build任务
            ],
        },
        //! 调用 make 编译代码 即 make -j16
        {
            "label": "build",
            "type": "shell",
            "command": "make",  //!< 或者mingw32-make
            "args": [
                "-j16", //!< 使用16线程同时编译
            ],
            "options": {
                "cwd": "${workspaceFolder}/build",
            },
            "group": {
                "kind": "build",
                "isDefault": true,
            },
            "dependsOn": [
                "cmake",    //!< 需要依赖cmake任务生成的makefile
            ],
        },
        //! 执行.exe程序  即 ./demo.exe
        {
            "label": "execute",
            "type": "shell",
            "command": "./*.exe",
            "options": {
                "cwd": "${workspaceFolder}/bin",    //!< .exe的路径,由CMakeLists.txt设置的
            },
            "group": {
                "kind": "test",
                "isDefault": true,
            },
            "dependsOn": [
                "build",    //!< 需要编译完成后才有.exe程序
            ],
        },
        //! 删除编译内容 build目录 即 rm -r ./build
        {
            "label": "clean",
            "type": "shell",
            "command": "rm",    //!< 或者del 应该rm兼容性好一些
            "args": [
                "-r",
                "./build",
            ],
            "options": {
                "cwd": "${workspaceFolder}",
            },
            "group": {
                "kind": "build",
                "isDefault": true,
            },
            // "dependsOn": [
            //     "build",
            // ],
        },
    ]
}

如何执行task任务?

点击终端--->运行任务--->选择对应的任务名即label

名称对应一个任务,如果是直接运行execute,则会依次调用mk_build---->cmake---->build---->execute 然后输出结果

因为tasks.json中设置了依赖关系,所以会依次调用,如果没有设置依赖关系,则需要按顺序挨个运行

结束语:部分借鉴了别的网友的博客,如有侵权,联系我删除

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/779490.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号