前言
在學(xué)習(xí)CMake
之前,一直都是自己在手敲Makefile
文件,當(dāng)項(xiàng)目的文件一旦多了起來,自己手動(dòng)寫Makefile
就不是那么好玩了,也曾經(jīng)了解了一下autotools
,但是seeed的柱哥說有CMake
這個(gè)東西,所以我就去學(xué)習(xí)了,也在網(wǎng)上搜過對(duì)比,下面的一句話讓我果斷放棄了autotools
:
CMake產(chǎn)生的晚,解決了很多autotools工具的問題
其實(shí)吧,簡單來說CMake
就是生成Makefile的自動(dòng)化構(gòu)建工具(自動(dòng)生成Makefile文件,不需要我們自己寫Makefile),引用一句官方的描述就是:
CMake 是一個(gè)跨平臺(tái)的構(gòu)建系統(tǒng)生成工具。它使用平臺(tái)無關(guān)的 CMake 清單文件CMakeLists.txt,指定工程的構(gòu)建過程;源碼樹的每個(gè)路徑下都有這個(gè)文件。CMake 產(chǎn)生一個(gè)適用于具體平臺(tái)的構(gòu)建系統(tǒng),用戶使用這個(gè)系統(tǒng)構(gòu)建自己的工程。
安裝CMake
- 開發(fā)環(huán)境:
Ubuntu
一句代碼的事安裝CMake
:
sudo apt-get install cmake
檢測安裝是否成功:
cmake --version
# 輸出
cmake version 3.10.2
CMake suite maintained and supported by Kitware (kitware.com/cmake).
如果你用的是vscode
寫代碼的話,最好還是裝一個(gè)CMake
插件,更加方便:
cmake插件
關(guān)于其他的一些注意事項(xiàng),你需要編譯c代碼,起碼Ubuntu得有個(gè)gcc編譯器啥的吧~如果沒有就直接安裝得了….### 初步了解CMake
其實(shí)呢,CMake
是非常簡單易用的,我們寫代碼無非就是將寫好的代碼進(jìn)行編譯生成可執(zhí)行文件,那么就可以用CMake
生成 Makefile 文件并編譯源代碼!
它的流程基本如下:
- 編寫
CMake
配置文件CMakeLists.txt
。 - 執(zhí)行
cmake PATH
命令生成Makefile
。其中,PATH
是CMakeLists.txt
所在的目錄。 - 使用
make
命令進(jìn)行編譯。(既然步驟2的時(shí)候就生成Makefile
文件了,那么肯定是可以直接make
編譯啦)
基本語法
一個(gè)最基本的CmakeLists.txt
文件最少需要包含以下3行代碼:
# CMake 最低版本號(hào)要求
cmake_minimum_required (VERSION 2.8)
# 項(xiàng)目信息
project (section1)
# 指定生成目標(biāo)
add_executable(section1 main.c)
注意 :CMake
的語法支持大寫、小寫甚至是大小寫混合的,實(shí)在是太變態(tài)了,不過呢,在杰杰的提供例程中使用的CMake
語法是小寫的,全局變量是大寫的,局部變量是小寫!
section1
廢話不多說,直接入門實(shí)戰(zhàn)吧,寫代碼這東西還是要親自動(dòng)手去寫采用意義~
- 文件夾目錄結(jié)構(gòu)如下:
jie@pc:~/github/cmake/section1$ tree
.
├── CMakeLists.txt
└── main.c
0 directories, 2 files
非常簡單,也就是一個(gè)main.c
文件與一個(gè)CMakeLists.txt
文件,內(nèi)容更是簡單,main.c
就只是打印個(gè)"Hello World!"
:
#include
int main(void)
{
printf("Hello World!\\n");
return 0;
}
CMakeLists.txt
就是CMake
最基礎(chǔ)的3行代碼:
# CMake 最低版本號(hào)要求
cmake_minimum_required (VERSION 2.8)
# 項(xiàng)目信息
project (section1)
# 指定生成目標(biāo)
add_executable(section1 main.c)
這樣子可以在該目錄下直接運(yùn)行以下命令去編譯(注意有一個(gè) 點(diǎn).
,表示CMakeLists.txt
所在的目錄):
cmake .
編譯輸出信息如下:
jie@pc:~/github/cmake/section1$ cmake .
-- The C compiler identification is GNU 7.4.0
-- The CXX compiler identification is GNU 7.4.0
-- Check for working C compiler: /usr/bin/cc
-- Check for working C compiler: /usr/bin/cc -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Detecting C compile features
-- Detecting C compile features - done
-- Check for working CXX compiler: /usr/bin/c++
-- Check for working CXX compiler: /usr/bin/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- Configuring done
-- Generating done
-- Build files have been written to: /home/jie/github/cmake/section1
然后你就會(huì)看到生成了一些其他文件文件以及一個(gè)Makefile
文件:
jie@pc:~/github/cmake/section1$ ls
CMakeCache.txt CMakeFiles cmake_install.cmake CMakeLists.txt main.c Makefile
既然有Makefile
文件那么就可以直接運(yùn)行make
命令去編譯源碼文件了,最后輸出“Built target section1”
表示編譯成功!最終目錄下會(huì)多出一個(gè)section1
可執(zhí)行文件,然后你運(yùn)行它就能看到代碼的執(zhí)行效果了,直接打印輸出"Hello World!"
。
jie@pc:~/github/cmake/section1$ make
Scanning dependencies of target section1
[ 50%] Building C object CMakeFiles/section1.dir/main.c.o
[100%] Linking C executable section1
[100%] Built target section1
CMakeLists.txt分析
# CMake 最低版本號(hào)要求
cmake_minimum_required (VERSION 2.8)
# 項(xiàng)目信息
project (section1)
# 指定生成目標(biāo)
add_executable(section1 main.c)
其實(shí)上面的三句代碼看起來像是函數(shù),但并不是函數(shù)而是命令,它跟我們的在linux
的命令差不多,反正就是指定CMake
要怎么做的一系列命令。比如:
cmake_minimum_required
:設(shè)置一個(gè)工程所需要的最低CMake
版本,如果CMake
的當(dāng)前版本低于指定的版本,它會(huì)停止處理工程文件,并報(bào)告錯(cuò)誤。project
:為整個(gè)工程設(shè)置一個(gè)工程名。add_executable
:使用給定的源文件,為工程引入一個(gè)可執(zhí)行文件。
add_executable( [WIN32] [MACOSX_BUNDLE]
[EXCLUDE_FROM_ALL]
source1 [source2 ...])
引入一個(gè)名字為
的可執(zhí)行目標(biāo),這個(gè)可執(zhí)行目標(biāo)會(huì)由調(diào)用該命令時(shí)在源文件列表中指定的源文件來構(gòu)建,比如main.c
就是一個(gè)源碼文件。
在工程范圍內(nèi)必須是全局唯一的,它實(shí)際上就是make編譯后生成的可執(zhí)行文件。
順便再提一下語法,上面的代碼呢,
是必須填寫的,然后也必須有一個(gè)源碼文件source1
,當(dāng)然有可以有多個(gè)源碼文件[source2 ...]
。
對(duì)了,#
后面的是注釋,這根C語言中//
表示注釋是一樣的!
代碼下載
https://github.com/jiejieTop/cmake
-
源碼
+關(guān)注
關(guān)注
8文章
639瀏覽量
29185 -
系統(tǒng)構(gòu)建
+關(guān)注
關(guān)注
0文章
7瀏覽量
6825 -
CMake
+關(guān)注
關(guān)注
0文章
28瀏覽量
1271
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論