最近,有没有被 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[1]
nmake 又是啥东西?
nmake 是 Microsoft Visual Studio 中的附带命令,需要安装 VS,实际上可以说相当于 linux 的 make,明白了么?
总结一下大体流程[2]
用编辑器编写源代码,如. c 文件。
用编译器编译代码生成目标文件,如. o。
用链接器连接目标代码生成可执行文件,如. exe。
但如果源文件太多,一个一个编译那得多麻烦啊?于是人们想到,为啥不设计一种类似批处理的程序,来批处理编译源文件呢?
于是就有了make工具,它是一个自动化编译工具,你可以使用一条命令实现完全编译。但是你需要编写一个规则文件,make 依据它来批处理编译,这个文件就是makefile,所以编写 makefile 文件也是一个程序员所必备的技能。
对于一个大工程,编写 makefile 实在是件复杂的事,于是人们又想,为什么不设计一个工具,读入所有源文件之后,自动生成 makefile 呢,于是就出现了cmake工具,它能够输出各种各样的 makefile 或者 project 文件, 从而帮助程序员减轻负担。但是随之而来也就是编写 cmakelist 文件,它是 cmake 所依据的规则。(cmake 中有很多设置库的,此时还不是可执行文件,而 make 生成后才是二进制可执行文件。)
所以在编程的世界里没有捷径可走,还是要脚踏实地的。