[software development] 科普: make makefile cmake nmake 都是些什么鬼
Tofloor
poster avatar
sammy-621
deepin
2023-08-18 16:51
Author

有没有被make、cmake、makefile... ... 这些东西绕晕了,看看下面的文章,也许就可以理解清楚了。

1. gcc

它是GNU Compiler Collection(就是GNU编译器套件),也可以简单认为是编译器,它可以编译很多种编程语言(括C、C++、Objective-C、Fortran、Java等等)。

我们的程序只有一个源文件时,直接就可以用gcc命令编译它。

可是,如果我们的程序包含很多个源文件时,该咋整?用gcc命令逐个去编译时,就发现很容易混乱而且工作量大,所以出现了下面make工具。

2. make

make工具可以看成是一个智能的批处理工具,它本身并没有编译和链接的功能,而是用类似于批处理的方式—通过调用makefile文件中用户指定的命令来进行编译和链接的。

3. makefile

这个是啥东西?

简单的说就像一首歌的乐谱,make工具就像指挥家,指挥家根据乐谱指挥整个乐团怎么样演奏,make工具就根据makefile中的命令进行编译和链接的。makefile命令中就包含了调用gcc(也可以是别的编译器)去编译某个源文件的命令。

makefile在一些简单的工程完全可以人工拿下,但是当工程非常大的时候,手写makefile也是非常麻烦的,如果换了个平台makefile又要重新修改,这时候就出现了下面的Cmake这个工具。

4. cmake

cmake就可以更加简单的生成makefile文件给上面那个make用。当然cmake还有其他更牛X功能,就是可以跨平台生成对应平台能用的makefile,我们就不用再自己去修改了。

可是cmake根据什么生成makefile呢?它又要根据一个叫CMakeLists.txt文件(学名:组态档)去生成makefile。

5. CMakeList.txt

到最后CMakeLists.txt文件谁写啊?亲,是你自己手写的。

6. nmake

nmake又是啥东西?

nmake是Microsoft Visual Studio中的附带命令,需要安装VS,实际上可以说相当于linux的make,明白了么?

image.png

总结一下大体流程

1.用编辑器编写源代码,如.c文件。

2.用编译器编译代码生成目标文件,如.o。

3.用链接器连接目标代码生成可执行文件,如.exe。

但如果源文件太多,一个一个编译那得多麻烦啊?于是人们想到,为啥不设计一种类似批处理的程序,来批处理编译源文件呢?

于是就有了make工具,它是一个自动化编译工具,你可以使用一条命令实现完全编译。但是你需要编写一个规则文件,make依据它来批处理编译,这个文件就是makefile,所以编写makefile文件也是一个程序员所必备的技能。

对于一个大工程,编写makefile实在是件复杂的事,于是人们又想,为什么不设计一个工具,读入所有源文件之后,自动生成makefile呢,于是就出现了cmake工具,它能够输出各种各样的makefile或者project文件,从而帮助程序员减轻负担。但是随之而来也就是编写cmakelist文件,它是cmake所依据的规则。(cmake中有很多设置库的,此时还不是可执行文件,而make生成后才是二进制可执行文件。)

原文: https://baijiahao.baidu.com/s?id=1730515159983772797&wfr=spider&for=pc

Reply Favorite View the author
All Replies
fuuko
deepin
2023-08-18 17:00
#1

还有一个 xmake,基于 lua 的对标 cmake 的工具,书写比 cmake 更贴合人类书写和阅读习惯,目前也在慢慢推广开ok

Reply View the author
enforcee
deepin
2023-08-18 17:24
#2

宣传一下我以前写的GNU构建系统简介
tail

Reply View the author
乾豫恒益
deepin
2023-08-18 17:25
#3

yeah agree

Reply View the author
阿尼樱奈奈
Moderator
2023-08-18 17:32
#4

like

Reply View the author
静夜思
Super Moderator
2023-08-18 17:40
#5

kissing_heart

Reply View the author
Jokul
deepin
2023-08-18 17:44
#6
fuuko

还有一个 xmake,基于 lua 的对标 cmake 的工具,书写比 cmake 更贴合人类书写和阅读习惯,目前也在慢慢推广开ok

还有还有qmakejoy

Reply View the author
jjcui8595
deepin
2023-08-18 18:08
#7

感谢分享like 学习了

Reply View the author
GXDEr
deepin
2023-08-18 18:32
#8
It has been deleted!
fuuko
deepin
2023-08-18 19:11
#9
Jokul

还有还有qmakejoy

qmake已经进入淘汰阶段了joy

Reply View the author
Jokul
deepin
2023-08-18 20:54
#10
fuuko

qmake已经进入淘汰阶段了joy

我现在学QT就是用qmake类型创建项目

Reply View the author
bluesky_
deepin
2023-08-18 22:19
#11
Jokul

我现在学QT就是用qmake类型创建项目

🤧 qt6已经明确放弃使用qmake了,虽然依旧能用,但是不维护了

Reply View the author
fuuko
deepin
2023-08-18 23:39
#12
Jokul

我现在学QT就是用qmake类型创建项目

学呗,qmake基于perl搞的,比cmake那种反人类的写法好一些,然而官方停止维护全面切cmake了

包括你看deepin下面的项目,基本都是用cmake组织的

Reply View the author