make, cmake, qmake 這些到底是什麼鬼??



 make 是用來執行Makefile的
 Makefile是類unix環境下(比如Linux)的類似於批處理的"腳本"文件。其基本語法是: 目標+依賴+命令,只有在目標文件不存在,或目標依賴的文件更舊,命令纔會被執行。由此可見,Makefile和make可適用於任意工作,不限於編程。比如,可以用來管理latex。
 Makefile+make可理解爲類unix環境下的項目管理工具,但它太基礎了,抽象程度不高,而且在windows下不太友好(針對visual studio用戶),於是就有了跨平臺項目管理工具cmake
 cmake是跨平臺項目管理工具,它用更抽象的語法來組織項目。雖然,仍然是目標,依賴之類的東西,但更爲抽象和友好,比如你可用math表示數學庫,而不需要再具體指定到底是math.dll還是libmath.so,在windows下它會支持生成visual studio的工程,在linux下它會生成Makefile,甚至它還能生成eclipse工程文件。也就是說,從同一個抽象規則出發,它爲各個編譯器定製工程文件。
 cmake是抽象層次更高的項目管理工具,cmake命令執行的CMakeLists.txt文件
 qmake是Qt專用的項目管理工具,對應的工程文件是*.pro,在Linux下面它也會生成Makefile,當然,在命令行下才會需要手動執行qmake,完全可以在qtcreator這個專用的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下的編譯器


gcc是GNU Compiler Collection(就是GNU編譯器套件),也可以簡單認爲是編譯器,它可以編譯很多種編程語言(括C、C++、Objective-C、Fortran、Java等等)。

當你的程序只有一個源文件時,直接就可以用gcc命令編譯它。

.但是當你的程序包含很多個源文件時,用gcc命令逐個去編譯時,你就很容易混亂而且工作量大

所以出現了make工具
make工具可以看成是一個智能的批處理工具,它本身並沒有編譯和鏈接的功能,而是用類似於批處理的方式—通過調用makefile文件中用戶指定的命令來進行編譯和鏈接的。

makefile是什麼?簡單的說就像一首歌的樂譜,make工具就像指揮家,指揮家根據樂譜指揮整個樂團怎麼樣演奏,make工具就根據makefile中的命令進行編譯和鏈接的。

makefile命令中就包含了調用gcc(也可以是別的編譯器)去編譯某個源文件的命令。

makefile在一些簡單的工程完全可以人工手下,但是當工程非常大的時候,手寫makefile也是非常麻煩的,如果換了個平臺makefile又要重新修改。

這時候就出現了Cmake這個工具,cmake就可以更加簡單的生成makefile文件給上面那個make用。當然cmake還有其他功能,就是可以跨平臺生成對應平臺能用的makefile,你不用再自己去修改了。

可是cmake根據什麼生成makefile呢?它又要根據一個叫CMakeLists.txt文件(學名:組態檔)去生成makefile。

到最後CMakeLists.txt文件誰寫啊?親,是你自己手寫的。

當然如果你用IDE,類似VS這些一般它都能幫你弄好了,你只需要按一下那個三角形

.接着是qmake,qmake是什麼,先說一下Qt這個東西。Qt是跨平臺C++圖形用戶界面應用程序開發框架。它既可以開發GUI程序,也可用於開發非GUI程序,比如控制檯工具和服務器。簡單的說就是C++的第三方庫,使用這個庫你可以很容易生成windows,Linux,MAC os等等平臺的圖形界面。現在的Qt還包含了開發各種軟件一般需要用到的功能模塊(網絡,數據庫,XML,多線程啊等等),比你直接用C++(只帶標準內褲那種)要方便和簡單。

.你可以用Qt簡簡單單就實現非常複雜的功能,是因爲Qt對C++進行了擴展,你寫一行代碼,Qt在背後幫你寫了幾百上千行,而這些多出來的代碼就是靠Qt專有的moc編譯器(The Meta-Object Compiler)和uic編譯器(User Interface Complier)來重新翻譯你那一行代碼。問題來了,你在進行程序編譯前就必須先調用moc和uic對Qt源文件進行預處理,然後再調用編譯器進行編譯。上面說的那種普通makefile文件是不適用的,它沒辦法對qt源文件進行預處理。所以qmake就產生了。

.qmake工具就是Qt公司製造出來,用來生成Qt 專用makefile文件,這種makefile文件就能自動智能調用moc和uic對源程序進行預處理和編譯。qmake當然必須也是跨平臺的,跟cmake一樣能對應各種平臺生成對應makefile文件。

qmake是根據Qt 工程文件(.pro)來生成對應的makefile的。工程文件(.pro)相對來說比較簡單,一般工程你都可以自己手寫,但是一般都是由Qt的開發環境 Qt Creator自動生成的,你還是只需要按下那個邪惡三角形就完事了。

還沒有完,由於qmake很簡單很好用又支持跨平臺,而且是可以獨立於它的IDE,所以你也可以用在非Qt工程上面,照樣可以生成普通的makefile,只要在pro文件中加入CONFIG -= qt 就可以了。

這樣qmake和cmake有什麼區別?
不好意思,cmake也是同樣支持Qt程序的,cmake也能生成針對qt 程序的那種特殊makefile,
只是cmake的CMakeLists.txt 寫起來相對與qmake的pro文件複雜點。
qmake 是爲 Qt 量身打造的,使用起來非常方便,但是cmake功能比qmake強大。
一般的Qt工程你就直接使用qmake就可以了,cmake的強大功能一般人是用不到的。
當你的工程非常大的時候,又有qt部分的子工程,又有其他語言的部分子工程,據說用cmake會 方便,我也沒試過。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章