使用CMake编译

CMake工具用于生成Makefile文件。用户通过编写CMakeLists.txt文件,描述构建过程(编译、连接、测试、打包),之后通过解析该文件,生成目标平台的Makefile文件,做到"Write once, run everywhere"。

 
 

使用CMake的方法很简单:

cmake <projectPath>

确保projectPath目录下,有CMakeLists.txt文件。该文件当然是用户来编写,所以重点是编写CMakeLists.txt,语法可以参考《CMake 入门实战》,或者官方入门文档:

https://cmake.org/cmake-tutorial/

PS:在Windows下使用时,需要使用VS自带的命令行,不然会找不到cl工具的错误。

 
 

成功执行cmake命令后,目录下会生成Makefile文件,不同编译平台生成的文件不同,编译工具也不同。

  • 如果是构建平台是MinGW,会什么makefile文件,使用mingw32-make构建。
  • 如果构建平台是VS系列,会生成vcxproj文件,可以使用msbuild工具构建。
  • 如果构造平台是NMake,可以使用nmake构建。

可以使用以下命令编译:

cmake --build <CMakeCachePath> --target <ProjectName>

CMakeCachePath是指CMakeCache.txt(或CMakeFiles文件夹)所在的路径。

 
 

可以使用以下命令清理编译结果:

cmake --build <CMakeCachePath> --target clean

 
 

如果CMakeLists.txt文件有修改,再次执行cmake命令,会更新Makefile文件。

 
 

关于编译平台的选择

可以使用以下命令,查看cmake支持的构建工具:

cmake -G

 
 

 
 

在生成Makefile时,指定构建工具:

cmake -G "<generator>" <projectPath>

generator可以是等号左边的名字。

 
 

例如,在Windows下,默认生成vcxproj文件(cmake 3.13.0-rc3 + VS2017),如果希望使用nmake构建,可以使用以下命令:

cmake -G "NMake Makefiles" <projectPath>

 
 

关于清理生存文件

存在一个问题,没找到较好的解决方案,如何清理CMake产生的文件?

A:可以使用"-B"参数指定生成目录,这样CMake生成的文件都会集中在这个文件,例如:

cmake -B <buildPath> .

之后在编译操作,均要在buildPath文件夹下执行。

特别的,还可以使用"-S"参数指定源码所在的文件夹,源码文件夹必须包含CMakeLists.txt。

详情可以参考:

https://cmake.org/cmake/help/v3.13/manual/cmake.1.html

CMakeLists.txt编写入门

可以使用Qt Creator新建一个CMake工程,每次修改后CmakeLists.txt文件后,可以在"General Messages"窗口,查看输出内容。

 
 

基础

CMakeLists.txt由命令构造成,每条命令占一行,换行符结尾,命令的格式如下:

commandName(arg1 arg2 …)

命令名不区分大小写参数间使用空格分隔

 
 

在CMakeLists.txt中,字符串同C语言中一样,使用双引号包含

 
 

输出

使用message()命令,输出信息,至少接受两个参数:

第一个参数指定信息的等级,为空的时候为重要信息,通常使用"STATUS"作为参数,代表该信息为普通说明信息。

第二个参数为一个字符串,可以跟随多个字符串。

例如:

message(STATUS "Hello World")

 
 

变量

使用set()命令,自定义变量,至少接受两个参数,第一个参数为变量名,第二个参数为变量的值。参数如果多于2个,那么该变量为一个集合。

特别的,可以使用以下命令设置系统环境变量:

set(ENV{<variable>} <value>...)

 
 

访问变量的格式如下:

${<variable>}

访问系统环境变量需要以下格式:

$ENV{<variable>}

 
 

CMake内置了许多变量,可以参考:

https://cmake.org/cmake/help/v3.13/manual/cmake-variables.7.html

 
 

常用的有:

PROJECT_NAME

项目名

PROJECT_BINARY_DIR

项目编译输出路径,调用cmake命令时,使用"-B"参数指定,默认为CMakeLists.txt所在的文件。

PROJECT_SOURCE_DIR

项目源码路径,调用cmake命令时,使用"-S"参数指定,默认为CMakeLists.txt所在的文件。

CMAKE_DEBUG_POSTFIX

CMAKE_RELEASE_POSTFIX

Debug/Release版的动态库后缀

CMAKE_BUILD_TYPE

编译类型(Debug、Release),该变量默认为空值

内置变量可以在调用cmake命令时,使用"-D"参数设置:

 
 

例子

推荐使用以下命令编译,这样生成的文件集中在build文件夹下,不会污染源码文件夹。

#cd进入CMakeLists.txt所在的文件夹

cmake -B .\build .

cmake --build .\build --target <ProjectName>

 

生成可执行文件

# 指定cmake最低版本

cmake_minimum_required(VERSION 2.8)

 
 

# 指定项目名

project(CppDemo)

# 生成可执行文件,第一个参数为目标名,之后参数为源文件列表

add_executable(${PROJECT_NAME} "main.cpp")

 
 

生成动态库

cmake_minimum_required(VERSION 2.8)

project(HelloWorld)

 
 

# 添加头文件

include_directories($ENV{JAVA_HOME}/include $ENV{JAVA_HOME}/include/win32)

 
 

# 设置生成目录

SET(LIBRARY_OUTPUT_PATH ${PROJECT_BINARY_DIR})

 
 

# 生成链接库文件,三个参数分别是链接库名、链接库类型、源码文件

add_library(${PROJECT_NAME} SHARED HelloWorld.cpp)

CMake简易入门的更多相关文章

  1. cmake 简易入门

    目录结构 root -| |--**.cpp |--CmakeList.txt |--current path |--(执行cmake ../) |-- (执行make的目录) 步骤: 1 编写 Cm ...

  2. JNI简易入门

    JNI简介 JNI(Java Native Interface)是JDK的一部分,提供了若干API实现了Java和其他语言的通信(主要是C/C++).JNI主要用于以下场景: 贴近硬件底层的功能,Ja ...

  3. 机器学习简易入门(四)- logistic回归

    摘要:使用logistic回归来预测某个人的入学申请是否会被接受 声明:(本文的内容非原创,但经过本人翻译和总结而来,转载请注明出处) 本文内容来源:https://www.dataquest.io/ ...

  4. Pandas简易入门(二)

    目录:     处理缺失数据     制作透视图     删除含空数据的行和列     多行索引     使用apply函数   本节主要介绍如何处理缺失的数据,可以参考原文:https://www. ...

  5. CMake快速入门教程-实战

    http://www.ibm.com/developerworks/cn/linux/l-cn-cmake/ http://blog.csdn.net/dbzhang800/article/detai ...

  6. 不用搭环境的10分钟AngularJS指令简易入门01(含例子)

    不用搭环境的10分钟AngularJS指令简易入门01(含例子) `#不用搭环境系列AngularJS教程01,前端新手也可以轻松入坑~阅读本文大概需要10分钟~` AngularJS的指令是一大特色 ...

  7. Web压力测试工具 LoadRunner12.x简易入门教程--(一)回放与录制

        LoadRunner12.x简易入门教程--(一)回放与录制 今天在这里分享一下LoadRunner12.x版本的入门使用方法,希望对刚接触LoadRunner的童鞋有所帮助. LoadRun ...

  8. 转:CMake快速入门教程-实战

    CMake快速入门教程:实战 收藏人:londonKu     2012-05-07 | 阅:10128  转:34    |   来源   |  分享               0. 前言一个多月 ...

  9. crontab简易入门

    前言 crontab是Unix和Linux用于设置周期性被执行的指令,是互联网很常用的技术,很多任务都会设置在crontab循环执行,如果不使用crontab,那么任务就是常驻程序,这对你的程序要求比 ...

随机推荐

  1. 对象复制帮助类---DeepCopy

    有的时候我们在对一个引用类型的对象进行传递操作的时候希望不要直接修改传递过来的对象,而是复制出一份来操作的时候就可以用下面的类进行复制 sing System.IO; using System.Run ...

  2. 由浅到深理解ROS(3)-命名空间

    全局命名空间: /rosout前面的反斜杠“/”表明该节点名称属于全局命名空间.之所以叫做全局名称因为它们在任何地方(包括代码.命令行工具.图形界面工具等的任何地方)都可以使用.无论这些名称用作众多命 ...

  3. 基于jquery的bootstrap在线文本编辑器插件Summernote (转)

    Summernote是一个基于jquery的bootstrap超级简单WYSIWYG在线编辑器.Summernote非常的轻量级,大小只有30KB,支持Safari,Chrome,Firefox.Op ...

  4. TP框架---thinkphp中ajax分页

    //点击类别后要显示的内容 public function pagechuli3()//这个方法的功能是根据ajax传过来的值查询数据,再将查询出来的数据返回到ajax,返回的默认是JSON类型. { ...

  5. 【BZOJ4927】第一题 双指针+DP(容斥?)

    [BZOJ4927]第一题 Description 给定n根直的木棍,要从中选出6根木棍,满足:能用这6根木棍拼 出一个正方形.注意木棍不能弯折.问方案数. 正方形:四条边都相等.四个角都是直角的四边 ...

  6. 记录-项目java项目框架搭建的一些问题(maven+spring+springmvc+mybatis)

    伴随着项目框架的落成后,本以为启动就能成功的,but.... 项目启动开始报错误1:java.lang.ClassNotFoundException: org.springframework.web. ...

  7. PhotoKit详解

    Photokit介绍 这篇主要介绍如何通过 Photokit获取数据 photokit.jpg 1,基类 PHObject Photos 框架中的根类PHObject只有一个公开接口 localIde ...

  8. Residual (numerical analysis)

    In many cases, the smallness of the residual means that the approximation is close to the solution, ...

  9. Symfony 如何使用ckeditor

    首先: 1)加载以下两个bundle "egeloen/ckeditor-bundle": "^4.0","helios-ag/fm-elfinder ...

  10. Linux:分区

    Linux:分区 分区表 磁盘分区表主要有两种格式,一种是限制较多的 MBR 分区表,一种是较新且限制较少的 GPT 分区表. MBR MBR 中,第一个扇区最重要,里面有主要开机记录(Master ...