make工程管理器就是一個「自動編譯管理器」,這裏的「自動」是指它可以根據文件時間戳自動發現跟新過的文件而減小工做量,同時,他經過讀入makefile文件的內容來執行大量編譯工做。用戶只須要使用一次簡單的編譯語句就能夠了,大大提升了工程的實際效率。linux
先來想象一個案例,假設個人執行檔裏面包含了四個原始碼檔案,分別是 main.c haha.c sin_value.c cos_value.c 這四個檔案,若是您想要讓這個程序能夠跑,那麼就須要這樣編譯spa
[root@linux ~]# gcc -c main.c [root@linux ~]# gcc -c haha.c [root@linux ~]# gcc -c sin_value.c [root@linux ~]# gcc -c cos_value.c # 先以上面的動做製做出四個目標文件,而後再進行下面的動做: [root@linux ~]# gcc -o main main.o haha.o sin_value.o cos_value.o \ > -lm -L/usr/lib -L/lib # 這樣就能夠製做出 main 這個執行檔囉!執行看看吧! [root@linux ~]# ./main HaHa! I'm the King of the world 0.706825 0.707388
若是能夠的話,能不能一個步驟就給他完成上面全部的動做呢? 試看看在這個目錄下創建一個 makefile 檔案,內容以下:命令行
# 1. 先創建編譯的規則 [root@linux ~]# vi makefile main: main.o haha.o sin_value.o cos_value.o gcc -o main main.o haha.o sin_value.o cos_value.o -lm # 注意:第二行的 gcc 以前是 <tab> 按鍵產生的空格喔! # 2. 嘗試給他創建規則看看 [root@linux ~]# rm -f main *.o <==先將以前的目標文件去除 [root@linux ~]# make cc -c -o main.o main.c cc -c -o haha.o haha.c cc -c -o sin_value.o sin_value.c cc -c -o cos_value.o cos_value.c gcc -o main main.o haha.o sin_value.o cos_value.o -lm # 這個時候 make 會主動去讀取 makefile 這個檔案的內容, # 並根據內容直接去給他編譯起相關的執行檔囉! # 3. 若是再執行一次 make 會怎樣?! [root@linux ~]# make make: `main' is up to date. # 看到了吧?!是否很方便呢?!
make 有這些好處:
• 簡化編譯時所須要下達的指令;code
• 若在編譯完成以後,修改了某個原始碼檔案,則 make 僅會針對被修改了的檔案進行編譯,其它 的 object file 不會被更動;blog
• 後能夠依照相依性來更新( update )執行檔。 get
make的基本規則爲:自動化
目標(target): 依賴條件 1 依賴條件 2 <tab> gcc -o 欲創建的執行文件 依賴條件 1 依賴條件 2
在makefile中包含三個要素:目標、依賴、命令。在makefile中只有一個最終目標,其餘目標都是這個目標連帶的。編譯
目標(target)就是咱們想要創建的信息,而依賴條件就是具備相關性的 object files ,那創建執行文件的語法就是以 <tab> 按鍵開頭的那一行!特別給他留意喔, 『命令列必需要以 tab 按鍵做爲開頭』才行! 他的規則基本上是這樣的: class
• 在 makefile 當中的 # 表明批註;效率
• <tab> 須要在命令行的第一個字符;
• 標的(target)與相依檔案(就是目標文件)之間需以『:』隔開。
makefile中可使用系統默認的自動化變量簡化命令:
$^:表明全部的依賴條件。
$@:表明目標文件
$<:表明一個目標文件