1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > CMake入门1——CMake与VS编译器和nmake的结合使用

CMake入门1——CMake与VS编译器和nmake的结合使用

时间:2022-01-21 12:51:51

相关推荐

CMake入门1——CMake与VS编译器和nmake的结合使用

下载安装例1 使用cmake-gui与VS生成器例3 PreLoadcmake用法

本文描述在Win10-64位系统中安装CMake、cmake-gui的简单使用及其与VS编译器的结合使用,以及cmake命令行与nmake的结合使用。

下载

从CMake官网上下载最新版本的安装包,本文中下载的是cmake-3.10.1-win64-x64.msi。若不想安装,可直接下载压缩包版本cmake-3.10.1-win64-x64.zip。

安装

CMake的安装非常简单。压缩包版本直接解压即可,安装版本也可一直点击下一步进行安装。为了使用方便,可将CMake配置到环境变量中,当然,这一步也可以在安装过程中设置。另外需要注意的是为了避免不必要的麻烦,路径中最好不要包括中文字符。下面简单描述一下安装过程。

双击下载的安装包,进入安装界面,点击[Next]。

勾选同意许可后,点击[Next]。

可在此处选择将CMake路径添加到环境变量中,并且创建CMake GUI程序的桌面快捷方式。然后点击[Next]。

可在此处自定义安装目录,设置好后点击[Next]。

开始安装,安装完成后点击[Next]。

安装完成,点击[Finish],结束安装过程。

安装完成后,即可使用CMake了。在命令行中输入"cmake --version",可看到如下图所示的输出。

例1 使用cmake-gui与VS生成器

本例使用cmake-gui和VS生成器构建出VS工程,然后用VS工具打开项目进行编译。

1. 新建CMakeTest目录,在CMakeTest目录下新建demo1目录,作为测试项目的根目录。在demo1下新建main.cpp和CMakeLists.txt文件。

main.cpp文件的内容很简单,就是输出一个提示字符串:

#include <iostream>using namespace std;void main(){cout<<"cmake test demo 1"<<endl;getchar();}

CMakeLists文件内容如下:

# CMake最低版本要求 cmake_minimum_required(VERSION 3.10.1)# 项目信息project(demo1)# 指定生成目标add_executable(demo main.cpp)

CMakeLists.txt 的语法比较简单,由命令、注释和空格组成。命令由命令名称、小括号和参数组成,参数之间使用空格进行间隔,且命令是不区分大小写的。符号 # 后面的内容被认为是注释。

对于上面的 CMakeLists.txt 文件,依次出现了几个命令:

cmake_minimum_required:指定运行此配置文件所需的 CMake 的最低版本,如果低于3.10.1版本,则构建过程会被终止project:参数值是 demo1,该命令表示项目的名称是 demo1add_executable: 将名为 main.cpp 的源文件编译成一个名称为 demo 的可执行文件

2. 打开cmake-gui程序,在上方配置两个目录:

第一个是CMakeLists文件目录,cmake据此开始执行第二个是cmake构建后的项目目录

3. 配置好点击[Configure]开始执行配置过程。首先会弹出编译器选择界面,此处使用默认的VS-32位编译器,直接点击[Finish],开始配置。

4. 第一次配置完成后如图所示,红色的两行是新的配置值,再次点击[Configure]即可。

5. 配置完成后,在build目录生成了如下的文件

6. 点击[Generate],开始生成VS项目

7. 生成完成后,在build目录下生成了demo1对于的VS项目

8. 通过点击cmake-gui中下放的[Open Project]按钮或者直接双击build目录下的demo1.sln,即可在VS中打开工程。

9. cmake生的demo1工程总共有3个项目

ZERO_CHECK:该项目会检查生成工程的 CMake 配置文件( CMakeLists.txt )是否更新。如更新,将运行 CMake 重新生成工程文件。如果确信 CMakeLists.txt 不会被更新,或者希望手工运行 CMake 重新生成工程文件,可以在 CMakeLists.txt 配置文件中添加 set(CMAKE_SUPPRESS_REGENERATION FALSE) 命令, ZERO_CHECK 目标将不会生成。ALL_BUILD:该目标会导致工程中所有项目被构建,类似 Visual Studio 的 Build All 或者 make 的 make all命令。demo:项目本身,就是在CMakeLists.txt文件中配置的project(demo1)

10. 在VS中通过单独生成项目demo1或者直接生成项目All_BUILD后,可以在build下的相应目录看到可执行文件demo.exe已经生成。双击demo.exe后,可以看到程序输出。

11. 如果不想用VS打开工程,也可以使用msbuild.exe编译demo1工程。首先需要打开VS命令行,因为cmake-gui中选择的编译器是32位的,所以此处选择”VS x86 本机工具命令提示符”。

打开后在命令行中进入到demo1的build目录,执行msbuild demo1.sln即可编译demo1项目。编译完成后可以在debug中看到生成的demo.exe文件,双击可运行。

#例2 使用cmake命令与nmake生成器 本例使用cmake命令行与nmake生成器构建Makefile,然后用nmake编译项目。

1. 新建项目demo2,将demo1中的main.cpp和CMakeLists.txt文件拷贝过来。将CMakeLists.txt文件中的project项目配置为demo2。 2. 同样从VS命令行进入到demo2目录,执行命令:

cmake -G "NMake Makefiles" .

执行完毕后,即可看到在demo2目录中生成了一些文件:

其中重要的是Makefile文件,这是用来编译项目的。在命令行中继续执行nmake命令开始编译,编译完成后可以看到在demo2目录生成了demo.exe程序。允许后可以看到输出。

例3 PreLoad.cmake用法

在命令行下使用cmake,需要用”-G”选项指定生成器。每次都输入感觉比较麻烦,可以将其配置在”PreLoad.cmake”文件中。新建项目demo3,准备好main.cpp和CMakeLists.txt文件,然后demo3目录下新建文件”PreLoad.cmake”,输入:

set(CMAKE_GENERATOR "NMake Makefiles" CACHE INTERNAL "" FORCE)

然后执行"cmake ."即可配置,然后执行"nmake"就可以编译。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。