共計 3120 個字符,預計需要花費 8 分鐘才能閱讀完成。
丸趣 TV 小編給大家分享一下 linux 中 makefile 指的是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
在 linux 中,makefile 是一個工程文件的編譯規則,描述了整個工程的編譯和鏈接等規則;其中包含了哪些文件需要編譯,哪些文件不需要編譯,哪些文件需要先編譯,哪些文件需要后編譯,哪些文件需要重建等等。
本教程操作環境:linux5.9.8 系統、Dell G3 電腦。
1、什么是 Makefile
Makefile 可以簡單的認為是一個工程文件的編譯規則,描述了整個工程的編譯和鏈接等規則。
一個企業級項目,通常會有很多源文件,有時也會按功能、類型、模塊分門別類的放在不同的目錄中,有時候也會在一個目錄里存放了多個程序的源代碼。
而 Makefle 就是針對如何對上述的一些代碼進行編譯的問題而生的,它定義了一套規則,決定了哪些文件要先編譯,哪些文件后編譯,哪些文件要重新編譯。
編譯整個工程需要涉及到的,在 Makefile 中都可以進行描述。換句話說,Makefile 可以使得我們的項目工程的編譯變得自動化,不需要每次都手動輸入一堆源文件和參數。
Makefile 的優點就是可以實現“自主編譯”,整個工程通常只要一個 make 命令就可以完成編譯、鏈接,甚至更復雜的功能。可以說,任何一個 Linux 源程序都帶有一個 Makefile 文件。
2.Makefile 的優點
管理代碼的編譯,決定該編譯什么文件,編譯順序,以及是否需要重新編譯;
節省編譯時間。如果文件有更改,只需重新編譯此文件即可,無需重新編譯整個工程;
一勞永逸。Makefile 通常只需編寫一次,后期就不用過多更改。
3. 命名規則
一般來說將 Makefile 命名為 Makefile 或 makefile 都可以,但很多源文件的名字是小寫的,所以更多程序員采用的是 Makefile 的名字,因為這樣可以將 Makefile 居前顯示。
如果將 Makefile 命為其它名字,比如 Makefile_demo,也是允許的,但使用的時候應該采用以下方式:
make -f Makefile_demo
4. 基本規則
Makefile 的基本規則為:
目標:依賴
(tab) 規則
目標 — 需要生成的目標文件
依賴 — 生成該目標所需的一些文件
規則 — 由依賴文件生成目標文件的手段
tab — 每條規則必須以 tab 開頭,使用空格不行
例如我們經常寫的 gcc test.c -o test,使用 Makefile 可以寫成:
test: test.c
gcc test.c -o test
其中,第一行中的 test 就是要生成的目標,test.c 就是依賴,第二行就是由 test.c 生成 test 的規則。
Makefile 中有時會有多個目標,但 Makefile 會將第一個目標定為終極目標。
5. 工作原理
目標的生成:
a. 檢查規則中的依賴文件是否存在;
b. 若依賴文件不存在,則尋找是否有規則用來生成該依賴文件。

比如上圖中,生成 calculator 的規則是 gcc main.o add.o sub.o mul.o p.o -o,Makefil 會先檢查 main.o, add.o, sub.o, mul.o, p.o 是否存在,如果不存在,就會再尋找是否有規則可以生成該依賴文件。
比如缺少了 main.o 這個依賴,Makefile 就會在下面尋找是否有規則生成 main.o。當它發現 gcc main.c -o main.o 這條規則可以生成 main.o 時,它就利用此規則生成 main.o,然后再生成終極目標 calculator。
整個過程是向下尋找依賴,再向上執行命令,生成終極目標。
目標的更新:
a. 檢查目標的所有依賴,任何一個依賴有更新時,就重新生成目標;
b. 目標文件比依賴文件時間晚,則需要更新。

比如,修改了 main.c,則 main.o 目標會被重新編譯,當 main.o 更新時,終極目標 calculator 也會被重新編譯。其它文件的更新也是類推。
6. 命令執行
make:
使用此命令即可按預定的規則生成目標文件。
如果 Makefile 文件的名字不為 Makefile 或 makefile,則應加上 - f 選項,比如:
make -f Makefile_demo
make clean:
清除編譯過程中產生的中間文件(.o 文件)及最終目標文件。
如果當前目錄下存在名為 clean 的文件,則該命令不執行。
— 解決辦法:偽目標聲明:.PHONY:clean
特殊符號:
–:表示此命令即使執行出錯,也依然繼續執行后續命令。如:
-rm a.o build/
@:表示該命令只執行,不回顯。一般規則執行時會在終端打印出正在執行的規則,而加上此符號后將只執行命令,不回顯執行的規則。如:
@echo $(SOURCE)
7. 普通變量
變量定義及賦值:
變量直接采用賦值的方法即可完成定義,如:
INCLUDE = ./include/
變量取值:
用括號括起來再加個美元符,如:
FOO = $(OBJ)
系統自帶變量:
通常都是大寫,比如 CC,PWD,CFLAG,等等。
有些有默認值,有些沒有。比如常見的幾個:
CPPFLAGS : 預處理器需要的選項 如:-I
CFLAGS:編譯的時候使用的參數 –Wall –g -c
LDFLAGS:鏈接庫使用的選項 –L -l
變量的默認值可以修改,比如 CC 默認值是 cc,但可以修改為 gcc:CC=gcc
8. 自動變量
常用自動變量:
Makefile 提供了很多自動變量,但常用的為以下三個。這些自動變量只能在規則中的命令中使用,其它地方使用都不行。
$@ — 規則中的目標
$ — 規則中的第一個依賴條件
$^ — 規則中的所有依賴條件
例如:
app: main.c func1.c fun2.c
gcc $^ – o $@
其中:$^ 表示 main.c func1.c fun2.c,$ 表示 main.c,$@表示 app。
模式規則:
模式規則是在目標及依賴條件中使用 % 來匹配對應的文件,比如在目錄下有 main.c, func1.c, func2.c 三個文件,對這三個文件的編譯可以由一條規則完成:
%.o:%.c
$(CC) –c $ -o $@
這條模式規則表示:
main.o 由 main.c 生成,
func1.o 由 func1.c 生成,
func2.o 由 func2.c 生成
這就是模式規則的作用,可以一次匹配目錄下的所有文件。
9. 函數
makefile 也為我們提供了大量的函數,同樣經常使用到的函數為以下兩個。需要注意的是,makefile 中所有的函數必須都有返回值。在以下的例子中,假如目錄下有 main.c,func1.c,func2.c 三個文件。
wildcard:
用于查找指定目錄下指定類型的文件,跟的參數就是目錄 + 文件類型,比如:
src = $(wildcard ./src/*.c)
這句話表示:找到./src 目錄下所有后綴為.c 的文件,并賦給變量 src。
命令執行完成后,src 的值為:main.c func1.c fun2.c。
patsubst:
匹配替換,例如以下例子,用于從 src 目錄中找到所有.c 結尾的文件,并將其替換為.o 文件,并賦值給 obj。
obj = $(patsubst %.c ,%.o ,$(src))
把 src 變量中所有后綴為.c 的文件替換成.o。
命令執行完成后,obj 的值為 main.o func1.o func2.o
特別地,如果要把所有.o 文件放在 obj 目錄下,可用以下方法:
ob = $(patsubst ./src/%.c, ./obj/%.o, $(src))
以上是“linux 中 makefile 指的是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注丸趣 TV 行業資訊頻道!