makefile中的all和 PHONY的作用

2021-12-29 21:40:17 字數 1358 閱讀 9081

main1.c:

#include

int main(void)

main2.c:

#include

int main(void)

【分析】:這裡需要生成兩個可執行檔案main1和main2(兩個目標)。由於makefile只能有乙個目標,所以可以構造乙個沒有規則的終極目標all,並以這兩個可執行檔案作為依賴。如下:

makefile:

all:main1 main2

main1: main1.c

@gcc main1.c -o main1

main2: main2.c

@gcc main2.c -o main2很多時候我們在執行make時會產生許多過程檔案,比如將上面的makefile改為:

makefile:

all:main1 main2

main1: main1.c

@gcc main1.c -o main1

main2: main2.o

@gcc main2.o -o main2

main2.o: main2.c

@gcc -c main2.c這樣就會生成乙個我們不需要的過程檔案main2.o。

如果希望將生成的過程檔案刪掉,根據前面再增加乙個目標clean:

all:main1 main2 clean

main1: main1.c

@gcc main1.c -o main1

main2: main2.o

@gcc main2.o -o main2

main2.o: main2.c

@gcc -c main2.c

clean:

@rm -f main2.o但是當我們make之後main2.o仍然存在,怎麼回事呢makefile中的all和.phony的作用

原來這裡的目標clean沒有任何依賴,make執行時認為這已經到「根上」了(就是認為磁碟上有clean,就像main2.c),將其忽略(儘管它有規則)。

關鍵字.phony可以解決這問題,告訴make該目標是「假的」(磁碟上其實沒有clean),這時make為生成這個目標就會將其規則執行一次。.phony修飾的目標就是只有規則沒有依賴。

加上一句.phony:clean即可:

all:main1 main2 clean

main1: main1.c

@gcc main1.c -o main1

main2: main2.o

@gcc main2.o -o main2

main2.o: main2.c

@gcc -c main2.c

.phony:clean

clean:

@rm -f main2.o

makefile中的all和 PHONY的作用

請編寫乙個makefile同時編譯 鏈結下面兩個程式 main1.c include int main void main2.c include int main void 分析 這裡需要生成兩個可執行檔案main1和main2 兩個目標 由於makefile只能有乙個目標,所以可以構造乙個沒有規則...

makefile中的 PHONY和all的作用

偽目標是這樣乙個目標 它不代表乙個真正的檔名,在執行make時可以指定這個目標來執行所在規則定義的命令,有時也可以將乙個偽目標稱為標籤。偽目標通過phony來指明。phony定義偽目標的命令一定會被執行,下面嘗試分析這種優點的妙處。1 如果我們指定的目標不是建立目標檔案,而是使用makefile執行...

makefile中的all和 PHONY的作用

main1.c include int main void printf main1 n main2.c include int main void printf main2 n 分析 這裡需要生成兩個可執行檔案main1和main2 兩個目標 由於makefile只能有乙個目標,所以可以構造乙個沒...