默認的情況下,make命令會在當前目錄下按順序找尋文件名爲"GNUmakefile"、"makefile"、"Makefile"的文件,找到了解釋這個文件。
在這三個文件名中,最好使用"Makefile"這個文件名,因爲,這個文件名第一個字符爲大寫,這樣有一種顯目的感覺。最好不要用"GNUmakefile",這個文件是GNU的make識別的。
target : dependents_1 dependents_2 ... dependents_n
command_1
command_2
command_3
(1)makefile中的變量賦值方式
makefile中定義的變量, 賦值中還有其他引用變量,makefile會將變量逐級展開
賦值操作符前後可以有若干空格
1> 操作符 =
遞歸展開引用變量, 直到找到被引用的變量的 最新值(搜索makefile)
var = I love
variable = linux
var += $(variable)
variable = magic
all:
@echo $(var)
輸出:
I love magic
2> 操作符 :=
遞歸展開引用變量, 只找到該變量賦值 之前 , 最新的引用變量的值 (不搜索整個makefile)
m := mm
x := $(m)
y := $(x) bar
x := later
all:
@echo $(x) $(y)
輸出:
$x ---> later
$y ---> mm bar
(若將 y:= 改成 y= ,$y值爲:later bar)
3>操作符 +=
可以通過+=爲已定義的變量添加新的值
當變量從前沒有被定義過, +=和=是一樣的,它定義一個遞歸展開的變量,但是,當變量已經有定義的時候,+=只是簡單的進行字符的添加工作。
如果起初你用:=定義變量,那麼+=只是利用變量的當前值進行添加
如果起初用=定義變量,+=的行爲就變得有些古怪,它並不會在使用+=的地方馬上進行變量展開,而是會把展開工作推後,直到它找到最後變量的定義,這和=定義變量的行爲是類似的
4>操作符 ?= (不奏效)
賦默認值,如果沒有初始化該變量,就給它賦上默認值。如:
ARCH=arm
ARCH ?= i386
all:
@echo $(ARCH)
輸出:
arm
ARCH=
ARCH ?= i386
all:
@echo $(ARCH)
輸出:
i386
(2)makefile主要預定變量
$*不包括擴展名的目標文件名稱
所有的依賴文件,以空格分開,並以出現的先後爲序,可能包含重複的依賴文件
%HTML_CONTENT%lt;第一個依賴文件的名稱
$?所有的依賴文件,以空格分開,這些依賴文件的修改日期比目標的創建日期晚
$@目標的完整名稱
$^所有的依賴文件,以空格分開,不包含重複的依賴文件
$%如果目標是歸檔成員,則該變量表示目標的歸檔成員名稱
(3)makefile中內定函數使用
1> wildcard
2> patsubst
3> notdir
SUB_DIR=./ locate order_maker scheduler transmit
INCLUDE = $(foreach temp,$(SUB_DIR), -I./$(temp))
SRC = $(foreach temp,$(SUB_DIR), $(wildcard $(temp)/*.cpp))
OBJS = $(foreach temp,$(SRC), $(patsubst %.cpp,%.o,$(temp)))
OBJS_LINK = $(foreach temp,$(OBJS), obj/$(patsubst %.cpp,%.o,$(notdir $(temp))))
(4)makefile中的文件搜索路徑
在makefile中,可以通過給 VPATH 賦值來設置規則中目標文件和依賴文件的搜索目錄。
Make首先搜索當前目錄,如果未找到依賴的文件,make將按照VPATH中給的目錄依次搜索VPATH對makefile中所有文件都有效。
如:
VPATH:=/c/ming \
/c/ming/head
也可以使用指令 vpath ,與VPATH在使用上的區別是:vpath可以給不同類文件指定不同的搜索目錄。
如:
vpath %.c /c/ming
vpath %.h /c/ming/head
vpath %.c 表示清除所有vpath對%.c設置的搜索目錄