[转]cmake的使用

转:https://blog.csdn.net/yaoyuanyylyy/article/details/79024962

下载
安装
例1 使用cmake-gui与VS生成器
例3 PreLoadcmake用法
本文描述在Win10-64位系统中安装CMake、cmake-gui的简单使用及其与VS2015编译器的结合使用,以及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();
}
1
2
3
4
5
6
7
8
CMakeLists文件内容如下:

# CMake最低版本要求 
cmake_minimum_required(VERSION 3.10.1)

# 项目信息
project(demo1)

# 指定生成目标
add_executable(demo main.cpp)
1
2
3
4
5
6
7
8
CMakeLists.txt 的语法比较简单,由命令、注释和空格组成。命令由命令名称、小括号和参数组成,参数之间使用空格进行间隔,且命令是不区分大小写的。符号 # 后面的内容被认为是注释。

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

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

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

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

3. 配置好点击[Configure]开始执行配置过程。首先会弹出编译器选择界面,此处使用默认的VS2015-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位的,所以此处选择”VS2015 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" .
1
执行完毕后,即可看到在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)
1
然后执行"cmake ."即可配置,然后执行"nmake"就可以编译。
--------------------- 
作者:元子丰 
来源:CSDN 
原文:https://blog.csdn.net/yaoyuanyylyy/article/details/79024962 
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值