作者:玟清 链接:https://www.php.cn/link/bf9b5a850f9afd054eb3bcd288c246c9 来源:知乎 著作权归作者所有,转载请联系作者获得授权。
- make 用于执行Makefile文件。 2. Makefile 是类unix环境(如Linux)下的一种类似批处理的“脚本”文件。其基本语法包括目标、依赖和命令,只有当目标文件不存在或比依赖文件更新时,命令才会执行。由此可见,Makefile 和 make 可用于任何工作,不仅限于编程,例如可以用来管理LaTeX。 3. Makefile 和 make 可以视为类Unix环境下的项目管理工具,但其抽象程度较低,且在Windows下对visual studio用户不友好,因此出现了跨平台项目管理工具cmake。 4. cmake 是跨平台项目管理工具,它使用更抽象的语法来组织项目。虽然仍然包括目标和依赖等概念,但更为抽象和友好。例如,你可以使用“math”表示数学库,而无需具体指定是math.dll还是libmath.so。在Windows下,它可以生成Visual Studio工程文件,在Linux下生成Makefile,甚至可以生成eclipse工程文件。也就是说,从同一个抽象规则出发,它为各个编译器定制工程文件。 5. cmake 是更高抽象层次的项目管理工具,执行的文件是CMakeLists.txt。 6. qmake 是qt专用的项目管理工具,对应的工程文件是.pro。在Linux下,它也会生成Makefile,当然,在命令行下需要手动执行qmake,但在Qt Creator这个专用ide中打开.pro文件时,不需要手动处理qmake的繁琐细节。 总结一下,make 用于执行Makefile,cmake 用于执行CMakeLists.txt,qmake 用于处理.pro工程文件。Makefile的抽象层次最低,cmake 和 qmake 在Linux等环境下最终还是会生成一个Makefile。cmake 和 qmake 支持跨平台,cmake 通过生成指定编译器的工程文件实现跨平台,而qmake 则自成体系。具体使用时,在Linux下,小型工程可以手动编写Makefile,大型工程可以使用automake生成Makefile,要实现跨平台,可以使用cmake。如果GUI使用了Qt,也可以使用qmake + .pro来管理工程,这也是跨平台的。当然,cmake 中也有针对Qt的一些规则,并替代qmake处理Qt相关的命令。另外,需要指出的是,make 和 cmake 的主要命令只有一条,make 用于处理Makefile,cmake 用于转译CMakeLists.txt,而qmake 是一个体系,用于支撑一个编程环境,它还包含除qmake 之外的其他多条命令(如uic、rcc、moc)。
上个简图,其中cl表示Visual Studio的编译器,gcc表示Linux下的编译器
作者:辉常哥 链接:https://www.php.cn/link/ce3f64221a4fbc9ed30d001c572bc5a3 来源:知乎 著作权归作者所有,转载请联系作者获得授权。
- gcc 是gnu Compiler Collection(GNU编译器套件),也可以简单认为是编译器,它可以编译多种编程语言(包括C、c++、Objective-C、Fortran、Java等)。 2. 当你的程序只有一个源文件时,可以直接使用gcc命令编译它。 3. 但是当你的程序包含多个源文件时,使用gcc命令逐个编译会很容易混乱且工作量大。 4. 因此出现了make工具。make工具可以视为一个智能的批处理工具,它本身不具备编译和链接功能,而是通过调用makefile文件中用户指定的命令来进行编译和链接。 5. makefile是什么?简单来说,就像一首歌的乐谱,make工具就像指挥家,指挥家根据乐谱指挥整个乐团如何演奏,make工具就根据makefile中的命令进行编译和链接。 6. makefile命令中就包含了调用gcc(也可以是其他编译器)去编译某个源文件的命令。 7. 在一些简单的工程中,makefile完全可以手动编写,但当工程非常大时,手写makefile也非常麻烦,如果换了平台,makefile又需要重新修改。 8. 这时就出现了cmake工具,cmake可以更简单地生成makefile文件供make使用。当然,cmake还有其他功能,可以跨平台生成对应平台可用的makefile,无需再手动修改。 9. 但是cmake根据什么生成makefile呢?它需要根据一个名为CMakeLists.txt的文件(学名:配置文件)来生成makefile。 10. 那么CMakeLists.txt文件由谁编写呢?当然是你自己手写的。 11. 如果你使用IDE,如Visual Studio,通常它都能帮你处理好,你只需点击那个三角形按钮。 12. 接下来是qmake,qmake是什么?先说一下Qt这个东西。Qt是跨平台的C++图形用户界面应用程序开发框架。它既可以开发GUI程序,也可以用于开发非GUI程序,比如控制台工具和服务器。简单来说,就是C++的第三方库,使用这个库你可以很容易生成Windows、Linux、Mac OS等平台的图形界面。现在的Qt还包含了开发各种软件通常需要用到的功能模块(如网络、数据库、xml、多线程等),比直接使用C++(只带标准库的那种)要方便和简单。 13. 你可以用Qt轻松实现非常复杂的功能,是因为Qt对C++进行了扩展,你写一行代码,Qt在背后帮你写了几百上千行,而这些额外的代码就是靠Qt专有的moc编译器(元对象编译器)和uic编译器(用户界面编译器)来重新翻译你那一行代码。问题来了,在程序编译前必须先调用moc和uic对Qt源文件进行预处理,然后再调用编译器进行编译。普通的makefile文件不适用,因为它无法对Qt源文件进行预处理。因此,qmake就出现了。 14. qmake工具是由Qt公司开发,用来生成Qt专用的makefile文件,这种makefile文件可以自动智能调用moc和uic对源程序进行预处理和编译。qmake当然也必须是跨平台的,像cmake一样可以对应各种平台生成对应的makefile文件。 15. qmake是根据Qt工程文件(.pro)来生成对应的makefile的。工程文件(.pro)相对来说比较简单,一般工程你都可以自己手写,但通常都是由Qt的开发环境Qt Creator自动生成的,你只需点击那个邪恶的三角形按钮就完成了。 16. 还没有完,由于qmake非常简单好用且支持跨平台,而且可以独立于它的IDE,所以你也可以将其用于非Qt工程,照样可以生成普通的makefile,只需在pro文件中加入CONFIG -= qt即可。 17. 那么qmake和cmake有什么区别呢?不好意思,cmake同样支持Qt程序,cmake也能生成针对Qt程序的特殊makefile,只是cmake的CMakeLists.txt编写起来比qmake的pro文件复杂一些。qmake是为Qt量身打造的,使用起来非常方便,但cmake的功能比qmake强大。一般的Qt工程你就直接使用qmake就可以了,cmake的强大功能一般人是用不到的。当你的工程非常大时,又有Qt部分的子工程,又有其他语言的部分子工程,据说使用cmake会更方便,但我也没试过。