a.默認情況下
1.make認為目標對應(yīng)一個文件
2.make比較目標文件和依賴文件的新舊關(guān)系,決定是否執(zhí)行命令
3.make以文件處理作為第一優(yōu)先級
示例
hello.out all : func.o main.o
gcc -o hello.out func.o main.o
func.o : func.c
gcc -o func.o -c func.c
main.o : main.c
gcc -o main.o -c main.c
clean :
rm *.o hello.out
該示例與之前的示例加上了clean
由上面的圖可以看出,在第二個我們假設(shè)在目錄下存在一個clean文件(可以通過touch命令來創(chuàng)建),如果我們此時運行make clean,會發(fā)現(xiàn)make總是提示clean文件是最新的,make這種行為從原理上來說是因為它將clean當作文件來處理,由于在當前目錄下找到了這個文件,加上clean目標沒有任何先覺條件,所以當要求make為我們創(chuàng)建clean目標時它就會認為clean是最新的,從而“拒絕”進行文件的清除操作。
出現(xiàn)這種情形,是因為我們對于clean目標的定義與make所理解的有所出入。目標文件名與Makefile中的目標名重名在現(xiàn)實項目中是難免的,所以假目標的概念被提出
makefile中的偽目標
1.通過.PHONY關(guān)鍵字聲明一個偽目標
2.偽目標不對應(yīng)任何實際的文件
3.不管偽目標的依賴是否更新,命令總是執(zhí)行
偽目標的語法:先聲明,后使用
加入.PHONY的示例
.PHONY: clean
hello.out all : func.o main.o
gcc -o hello.out func.o main.o
func.o : func.c
gcc -o func.o -c func.c
main.o : main.c
gcc -o main.o -c main.c
clean :
rm *.o hello.out
運行結(jié)果如圖所示
如圖所示,我們可以看出在當前目錄下即使存在clean文件,有了偽目標.PHONY的使用運行make clean命令會執(zhí)行刪除操作
1.makefile中支持程序設(shè)計語言中變量的概念
2.makefile中的變量只代表文本數(shù)據(jù)(字符串)
3.makefile中的變量名規(guī)則
(變量名可以包含字符、數(shù)字、下劃線;不能包含“:”,“#”,“=”或“ ”;變量名大小寫敏感)
A.變量的定義和使用(通過使用變量可以使得Makefile更具有可維護性)
.PHONY: clean
CC:=gcc
TARGET:=hello.out
$(TARGET) : func.o main.o
$(CC) -o $(TARGET) func.o main.o
func.o : func.c
$(CC) -o func.o -c func.c
main.o : main.c
$(CC) -o main.o -c main.c
.PHONY : rebuild clean all
rebuild : clean all
all : $(TARGET)
clean :
rm *.o $(TARGET)
運行結(jié)果如圖示
可以看到在加入了變量之后,生成的結(jié)果是一樣的
B.makefile中變量的賦值方式
1.簡單賦值(:=)
2.遞歸賦值(=)
3.條件賦值(?=)
4.追加賦值(+=)
a.簡單賦值(:=)
1.程序設(shè)計語言中的通用的賦值方式
2.只針對當前語句的變量有效
.PHONY: all
x=foo
y=$(x)b
x=later
xx:=foo
yy:=$(xx)b
ixx:=later
all:
@echo "xx=$(xx),yy=$(yy)"
結(jié)果如圖
b.遞歸賦值(=)
1.賦值操作可能影響多個其他變量
2.所有與目標變量相關(guān)的其他變量都將受到影響
.PHONY: all
foo=$(bar)
bar=$(ugh)
ugh=MYLOVE
all:
@echo $(foo)
結(jié)果如圖
c.條件賦值(?=)
1.如果變量未定義,使用賦值符號中的值定義變量
2.如果變量已經(jīng)定義,則賦值無效
.PHONY: all
x:=foo
y:=$(x)b
x?=new
all:
@echo "x=>$(x)"
@echo "y=>$(y)"
d.追加賦值(+=)
1.原變量值之后加上一個新值
2.原變量值與新值之間由空格隔開
.PHONY: all
x:=foo
y:=$(x)b
x+= $(y)
all:
@echo "x=>$(x)"
@echo "y=>$(y)"
1.$@ 用于表示一個規(guī)則的目標 當一個規(guī)則中有多個目標時 $@所指的是其中任一造成規(guī)則命令被運行的目標
2.$^ 表示的是規(guī)則中的所有先決條件
3.$< 表示的是規(guī)則中的第一個先決條件
運用這些規(guī)則對之前的代碼進行修改
CC := g++
TARGET := hello.out
$(TARGET) : func.o main.o
$(CC) -o $@ $^
func.o : func.c
$(CC) -o $@ -c $^
main.o : main.c
$(CC) -o $@ -c $^
.PHONY : rebuild clean all
rebuild : clean all
all : $(TARGET)
clean :
$(RM) *.o $(TARGET)
結(jié)果如圖所示
這樣寫的原因在之前就已經(jīng)提到使得Makefile更具有可維護性
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。