CMake語法及CMakeList.txt簡單使用小結(jié)
CMake簡單介紹
Cmake主要用于開發(fā)跨平臺的C++項目,對于Windows程序員來說,在Linux上開發(fā)C++程序會非常困難,一來沒用過makefile,其語法非常生疏難懂,二來visual studio編譯器實在優(yōu)點太多(目前最新推出的vs2022中開啟效率得到了質(zhì)的提升,而且內(nèi)置的IntelliCode更是直呼內(nèi)行)。這就導致C++不同于其他語言,硬生生催生出Windows程序員和Linux程序員兩個群體,直到出現(xiàn)CMake這個局面才被打破。
CMake可以在Linux上自動生成makefile,在Windows下可以生成vs解決方案sln,對于大規(guī)??缙脚_項目絕對是首選。相比于makefile,CMake語法要簡單的多。自vs2017之后vs便支持CMake語法,到目前vs2022仍然支持,其效果之不必多說。
TIPS:以下均使用vs2022進行介紹。
創(chuàng)建項目


TIPS:解決方案就是項目的合集,項目是對應每一個靜態(tài)庫,動態(tài)庫和可執(zhí)行文件的編譯目標。
創(chuàng)建完成

TIPS:建議紅色框框里面的內(nèi)容一定要看一遍。

用CMake構(gòu)建一個項目工程,是通過一個或多個CMakeLists.txt文件來控制的。CMakeLists.txt中包含一系列命令來描述需要執(zhí)行的構(gòu)建。
CMake語法
在CMakeLists.txt中的命令的語法,都是形如下面這種格式:
command (args ...)
- command:命令的名字
- args:參數(shù)列表。多個參數(shù)使用空格隔開。
常用的命令
cmake_minimum_required
設置項目要求的CMake最低版本號,如果當前版本的CMake低于所需的值,它將停止處理項目并報告錯誤。注意務必在project之前調(diào)用該命令,一般是在CMakeLists.txt文件開頭調(diào)用。命令格式為:
cmake_minimum_required(VERSION major.minor[.patch[.tweak]] [FATAL_ERROR])
使用示例:
cmake_minimum_required(VERSION 2.8.5) cmake_minimum_required(VERSION 3.8)
add_executable
使用指定的源文件給項目添加一個可執(zhí)行文件。命令格式為:
add_executable(<name> [WIN32] [MACOSX_BUNDLE] [EXCLUDE_FROM_ALL] source1 [source2 ...])
參數(shù)介紹:
- name:該命令調(diào)用列出的源文件來構(gòu)建的可執(zhí)行目標。 對應于邏輯目標名稱,在項目中必須是全局唯一的。構(gòu)建的可執(zhí)行文件的實際文件名是基于本機平臺的約定。
- WIN32:如果給出WIN32,則在創(chuàng)建的目標上設置屬性WIN32_EXECUTABLE。
- MACOSX_BUNDLE:如果給定MACOSX_BUNDLE,將在創(chuàng)建的目標上設置相應的屬性。
- EXCLUDE_FROM_ALL:如果給定EXCLUDE_FROM_ALL,將在創(chuàng)建的目標上設置相應的屬性。
- source:源碼列表。
使用示例:
add_executable (CMakeClient0331 "CMakeClient0331.cpp" "CMakeClient0331.h")
project
為整個工程設置一個工程名。命名格式為:
project (<PROJECT-NAME> [LANGUAGES] [<language-name>...]) project (<PROJECT-NAME> [VERSION <major>[.<minor>[.<patch>[.<tweak>]]]] [LANGUAGES<language-name>...])
使用示例:
project ("CMakeClient0331")set
將一個CMAKE變量設置為給定值。命名格式為:
set(<variable> <value>... [PARENT_SCOPE])
使用示例:
set(COCOS2D_ROOT ${CMAKE_SOURCE_DIR}/cocos2d)常用的變量
使用${ }進行變量的引用。例如:message(${CMAKE_VERSION}),表示向用戶顯示cmake的完整版本號。CMake還提供了很多有用的變量。以下僅列舉常用的變量:
CMAKE_BINARY_DIR:構(gòu)建樹的頂層路徑CMAKE_COMMAND:指向CMake可執(zhí)行文件的完整路徑CMAKE_CURRENT_BINARY_DIR:當前正在被處理的二進制目錄的路徑。CMAKE_CURRENT_SOURCE_DIR:指向正在被處理的源碼目錄的路徑。CMAKE_HOME_DIRECTORY:指向源碼樹頂層的路徑。CMAKE_PROJECT_NAME:當前工程的工程名。CMAKE_ROOT:CMake的安裝路徑。CMAKE_SOURCE_DIR:源碼樹的頂層路徑。CMAKE_VERSION:cmake的完整版本號。PROJECT_BINARY_DIR:指向當前編譯工程構(gòu)建的全路徑。<PROJECT-NAME>_BINARY_DIR:指向當前編譯工程構(gòu)建的全路徑。<PROJECT-NAME>_SOURCE_DIR:指向構(gòu)建工程的全路徑。PROJECT_SOURCE_DIR:指向構(gòu)建工程的全路徑。PROJECT_NAME:project命令傳遞的工程名參數(shù)。<PROJECT-NAME>_VERSION:項目的完整版本號。
內(nèi)置宏
- EXECUTABLE_OUTPUT_PATH :用于確定可執(zhí)行文件的輸出路徑
- CMAKE_ARCHIVE_OUTPUT_DIRECTORY:靜態(tài)庫lib的輸出路徑
- CMAKE_DEBUG_POSTFIX:設置Debug版本下的庫文件后綴名
- CMAKE_RELEASE_POSTFIX:設置Release版本下庫文件的后綴名
簡單使用實例
以下項目中的CMakeLists.txt文件內(nèi)容如下(應用場景為:生成客戶端和服務端的可執(zhí)行文件,同時指定生成可執(zhí)行文件的目錄),根目錄的CMakeLists.txt無需修改。

# CMakeList.txt: Server0327 的 CMake 項目,在此處包括源代碼并定義
# 項目特定的邏輯。
#
cmake_minimum_required (VERSION 3.8)
#exe程序的路徑
set(EXECUTABLE_OUTPUT_PATH ${PROJECT_SOURCE_DIR}/../bin)
# 將源代碼添加到此項目的可執(zhí)行文件。
add_executable (Server "Server0327.cpp" "Server0327.h")
add_executable (Client "CMakeClient0331.cpp" "CMakeClient0331.h")
# TODO: 如有需要,請?zhí)砑訙y試并安裝目標。
運行效果展示



到此這篇關(guān)于CMake語法及CMakeList.txt簡單使用小結(jié)的文章就介紹到這了,更多相關(guān)CMake語法及CMakeList.txt使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
VC自定義消息響應函數(shù)postmessage用法示例
這篇文章主要介紹了VC自定義消息響應函數(shù)postmessage用法示例,并對比說明了postmessage與sendmessage的用法區(qū)別,需要的朋友可以參考下2014-10-10
C++實現(xiàn)LeetCode(156.二叉樹的上下顛倒)
這篇文章主要介紹了C++實現(xiàn)LeetCode(156.二叉樹的上下顛倒),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07
C++左值與右值,右值引用,移動語義與完美轉(zhuǎn)發(fā)詳解
這篇文章主要為大家詳細介紹了Python實現(xiàn)學生成績管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03

