【交叉编译踩坑指北(一)】windows10下Vscode与Cmake编译生成文件

1、工具链安装

  工具链版本如下

C:\Users\Lenovo>cmake -version
cmake version 3.24.2

C:\Users\Lenovo>mingw32-make -v
GNU Make 4.2.1 Built for x86_64-w64-mingw32

  若没有以上工具则进行安装,将bin文件加入到环境变量中,注意:有的交叉编译器在安装时选择自动加入环境变量可能并不会加入,还是需要手动加入环境变量,本章首先介绍MinGW编译器,其环境变量如图中所示,位于D盘bin目录下
在这里插入图片描述  该目录下包含了mingw的一系列工具链
  包括mingw的make文件,mingw32-make(在运行makefile时要使用mingw32-make而不是make)
在这里插入图片描述
  还有mingw的gcc文件,用于编译.c文件生成可执行文件
在这里插入图片描述
  它们的关系是这样的:make用于执行Makefiles,Makefiles中包含了一系列的gcc语句用于编译连接,因此make相当于借助makefiles执行一系列gcc指令的指令。(这里的make代表了一系列的make工具,对于mingw是mingw32-make,对于其他工具可能是其他名字。gcc也同理,这里是x86_64-w64-mingw32-gcc)


  一个小探究,这里发现mingw的bin文件夹下除了x86_64-w64-mingw32-gcc还有一个gcc文件,但当我们在cmd中查看他们各自的版本时发现提示是一样的

C:\Users\Lenovo>gcc -v Using built-in specs. COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=D:/mingw64/bin/…/libexec/gcc/x86_64-w64-mingw32/8.1.0/lto-wrapper.exe
Target: x86_64-w64-mingw32

C:\Users\Lenovo>x86_64-w64-mingw32-gcc -v Using built-in specs.
COLLECT_GCC=x86_64-w64-mingw32-gcc
COLLECT_LTO_WRAPPER=D:/mingw64/bin/…/libexec/gcc/x86_64-w64-mingw32/8.1.0/lto-wrapper.exe
Target: x86_64-w64-mingw32

  应当是都被重定向到了同一个可执行文件


2、安装Vscode插件

C/C++
Cmake
Cmake Tools

在这里插入图片描述

3、CMake介绍

  CMake是一个跨平台的Makefile生成工具
  依赖的文件是CMakeLists.txt,其作用简单归结为:

cmake执行CMakeLists.txt生成Makefiles,然后make执行Makefiles,调用Makefiles中一系列gcc编译生成可执行的目标文件

  在这个过程中,make有不同的工具,gcc也有不同的工具,因此在整个工具链中需要进行配置。例如如果是生成windows可执行文件,Cmake就要配置生成MinGW Makefiles,执行Makefiles要选择mingw32-make,编译器要选择x86_64-w64-mingw32-gcc

4、VScode中CMake的使用

shift+ctrl+P:并输入如下指令
cmake:quick start

为本工程开启CMake tools

然后就会看到cmake tools在vscode中的UI
在这里插入图片描述可以点击这里在这里插入图片描述

来进行配置编译器的选择,比如mingw编译器或者arm交叉编译器

5、操作流程(简易版Cmake,无文件层次)

5.1创建文件夹并在VScode中打开

在这里插入图片描述

  在桌面上新建了一个空文件夹test_hello,并在VScode中打开文件夹

5.2创建文件hello.c

hello.c

#include<stdio.h>
int main(){
    printf("HELLO\n");
    return 0;
}

在这里插入图片描述

5.3创建文件CMakeLists.txt

CMakeLists.txt

#cmake使用#注释
cmake_minimum_required(VERSION 3.0)#指定最低版本,不超过前面查看的当前版本
project(hello_simple)#指定当前项目名称
add_executable(hello hello.c)#指定生成目标、源文件

在这里插入图片描述

5.4配置VScode插件CMakeTools选项

进入用户设置
在这里插入图片描述

选择CMakeTools设置
在这里插入图片描述


可以看到生成文件的默认目录是会在当前文件夹下创建一个build文件夹,生成文件都生成在这个build文件夹中
在这里插入图片描述


此外还有源代码目录选择,这个和build一样,都先默认不设置
在这里插入图片描述




CMake生成器(Generator)配置。
CMake不编译或链接任何源文件,它使用生成器为构建系统创建配置文件。
相当于在终端(cmd或者powershell)中输入cmake -G后面的参数,例如cmake -G “MinGW Makefiles”
在这里插入图片描述
在终端输入

cmake -help

可以看到-G可选参数,其中常见的有这几种。也就是说在上述Cmake:Generator中可选这些生成器,*号表示默认的生成器
在这里插入图片描述

5.5开启CMakeTools的UI并选择编译器
shift+ctrl+P

弹出的窗口输入:

cmake:quick start

在这里插入图片描述


并点击,会弹出来如下选择
在这里插入图片描述第一次使用时推荐第一个,这个会在本机中扫描编译器和交叉编译器(前提是必须先添加到系统环境变量中,详见本章第一节),特别是遇到BC没出现的情况时,点击A后UI会自动启动,然后在窗口底部的这个位置可以点击选择编译器。
在这里插入图片描述这里选择x86_64-w64-mingw32-gcc 构建windows系统的可执行文件,则生成文件是exe格式的。



点击build进行构建,部分输出如下
在这里插入图片描述可以根据提示知道最后成功构建了可执行文件hello.exe(在build文件下)

由此可知,VScode中的CMakeTools可以一步到位完成构建生成,而不是像终端中那样,先构建生成Makefile,然后再用make指令生产最终可执行文件。


这里稍微拓展一下,如果要在终端进行构建的话,如果前面cmake -G参数选的是MinGw Makefiles,那么后面make指令就要选mingw工具链中的make,即mingw64-make(第一节中所介绍的)指令来执行Makefile,这体现了工具链的对应性和一致性


5.6执行生成文件,观察结果

在这里插入图片描述
可以看到,生成文件都在build中,包含了中间文件Makefile,还有目标文件hello.exe等。
直接在终端中cd到build下(输入E: 按下回车可以改变到对应盘符)输入

./hello.exe

结果如下,这里用的是VScode内置powershell
在这里插入图片描述成功输出结果,圆满完成任务!

  • 9
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以在 Visual Studio Code 中使用 CMake 插件来编译 CMake 项目。首先,你需要在 VS Code 中安装 CMake 工具。然后,在项目文件夹中创建一个名为 build 的文件夹,并在该文件夹中生成 cmake 配置文件。接下来,你可以在 VS Code 中打开该项目,并通过 CMake 工具栏中的按钮来编译项目。更多详细信息可以参考 VS Code CMake 插件的官方文档。 ### 回答2: 在Windows下使用VSCode进行CMake编译的步骤如下: 1. 首先,确保你已经安装了Visual Studio Code和CMake。 2. 打开VSCode,点击左侧的文件资源管理器(Explorer)图标,选择你要进行CMake编译的项目文件夹。 3. 在顶部菜单栏中选择“视图(View)”->“终端(Terminal)”以打开集成终端。 4. 在终端窗口中,使用cd命令切换到你的项目目录。例如,如果你的项目存储在D盘的code文件夹中,你可以输入以下命令:`cd D:/code`。 5. 确保你的项目目录下包含了CMakeLists.txt文件,该文件描述了CMake编译过程。 6. 在VSCode的终端窗口中,输入以下命令来创建一个build目录,并切换到该目录:`mkdir build && cd build`。 7. 接下来,使用cmake命令来进行CMake的配置。例如,你可以使用以下命令:`cmake ..`。这会在build目录下生成相应的构建文件。 8. 完成配置后,可以使用cmake --build命令进行编译。例如,如果你想使用MSBuild进行编译,可以使用以下命令:`cmake --build . --config Debug`。 9. 如果编译成功,你将在build目录下找到生成的可执行文件。 10. 在VSCode的终端窗口中,可以使用该可执行文件的路径来运行程序。 总结:以上是在Windows下使用VSCode进行CMake编译的基本步骤。确保你已经正确配置了CMakeLists.txt文件,以便生成正确的构建文件。在构建过程中,你可以根据需要选择不同的编译器和配置。 ### 回答3: 在Windows下使用VSCode进行CMake编译可以分为以下几个步骤: 1. 安装VSCodeCMake:首先要确保已经在Windows上安装好了VSCodeCMake。可以到官网下载安装包并按照指引进行安装。 2. 安装CMake插件:在VSCode中,打开“Extensions”面板,搜索并安装CMake插件。该插件提供了用于构建和调试CMake项目的功能。 3. 创建CMake项目:在VSCode中,选择一个适当的文件夹作为项目根目录,右键点击,选择“在终端中打开”选项。然后在终端中输入以下命令,创建CMakeLists.txt文件: ``` cmake -B build ``` 4. 配置CMake插件:在VSCode中,按下“Ctrl + Shift + P”打开命令面板,输入“CMake: Configure”并选择。然后在弹出的输入框中选择刚才创建的“build”文件夹作为构建文件夹。 5. 构建项目:继续在命令面板中输入“CMake: Build”并选择。CMake插件将根据CMakeLists.txt文件的内容和构建文件夹的设置来编译项目。编译输出将显示在终端中。 6. 调试项目(可选):如果项目需要调试支持,可以通过在CMakeLists.txt文件中添加相应的调试配置来启用调试功能。然后可以在VSCode中配置调试器,并通过调试面板进行调试操作。 总结:通过安装CMake插件、创建CMakeLists.txt文件并进行配置,以及使用CMake插件进行构建,可以在Windows下使用VSCode进行CMake编译。在构建过程中,可以根据需要选择是否启用调试功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值