makefile中的all和.PHONY的作用

本文介绍了一个具体的Makefile案例,演示如何通过Makefile同时编译并链接两个简单的C程序,即main1和main2。此外,还介绍了如何清理中间文件以及使用.PHONY关键字来确保清理规则的正确执行。
摘要由CSDN通过智能技术生成

请编写一个makefile同时编译、链接下面两个程序:

main1.c:

#include<stdio.h>

int main(void)

{

   printf("main1\n");

}

main2.c:

#include<stdio.h>

int main(void)

{

   printf("main2\n");

}

【分析】:这里需要生成两个可执行文件main1main2(两个目标)。由于makefile只能有一个目标,所以可以构造一个没有规则的终极目标all,并以这两个可执行文件作为依赖。如下:

makefile:

all:main1main2

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:main1main2 clean

main1: main1.c

    @gccmain1.c -o main1

main2: main2.o

    @gccmain2.o -o main2

main2.o: main2.c

   @gcc -cmain2.c 

.PHONY:clean

clean:

    @rm -fmain2.o

 

【附】

phony ['fəuni] a. 假的

GNU的make能够使整个软件工程的编译、链接只需要一个命令就可以完成。

makefile的术语:

规则:用于说明如何生成一个或多个目标文件

规则的格式:

targetsprerequisites

   command

目标 依赖

   命令

+++++命令需要以[TAB]键开始++++


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值