首页 > 代码库 > makefile中的all和.PHONY的作用
makefile中的all和.PHONY的作用
请编写一个makefile同时编译、链接下面两个程序:
1 main1.c: 2 #include<stdio.h> 3 int main(void) 4 { 5 printf("main1\n"); 6 } 7 main2.c: 8 #include<stdio.h> 9 int main(void) 10 { 11 printf("main2\n"); 12 }
【分析】:这里需要生成两个可执行文件main1和main2(两个目标)。由于makefile只能有一个目标,所以可以构造一个没有规则的终极目标all,并以这两个可执行文件作为依赖。如下:
1 makefile: 2 all:main1 main2 3 main1: main1.c 4 @gcc main1.c -o main1 5 main2: main2.c 6 @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
【附】
phony [‘f?uni] a. 假的
GNU的make能够使整个软件工程的编译、链接只需要一个命令就可以完成。
makefile的术语:
规则:用于说明如何生成一个或多个目标文件
规则的格式:
targets:prerequisites
command
目标: 依赖
命令
+++++命令需要以[TAB]键开始++++
makefile中的all和.PHONY的作用
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。