makefile中的.PHONY和all的作用

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/tonglin12138/article/details/88636170

.PHONY(伪目标)

伪目标是这样一个目标:它不代表一个真正的文件名,在执行make时可以指定这个目标来执行所在规则定义的命令,有时也可以将一个伪目标称为标签。伪目标通过PHONY来指明。

 PHONY定义伪目标的命令一定会被执行,下面尝试分析这种优点的妙处。

1、如果我们指定的目标不是创建目标文件,而是使用makefile执行一些特定的命令,例如:

clean:
        rm *.o temp

我们希望,只要输入”make clean“后,”rm *.o temp“命令就会执行。但是,当当前目录中存在一个和指定目标重名的文件时,例如clean文件,结果就不是我们想要的了。输入”make clean“后,“rm *.o temp” 命令一定不会被执行。

解决的办法:将目标clean定义成伪目标就成了 无论当前目录下是否存在“clean”这个文件,输入“make clean”后,“rm *.o temp”命令都会被执行。

注意:这种做法的带来的好处还不止此,它同时提高了make的执行效率,因为将clean定义成伪目标后,make的执行程序不会试图寻找clean的隐含规则。

2、PHONY可以确保源文件(*.c *.h)修改后,对应的目标文件会被重建。

all

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

main1.c:

#include

int main(void)

{

    printf("main1\n");

}

main2.c:

#include

int main(void)

{

    printf("main2\n");

}

【分析】:这里需要生成两个可执行文件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改为:

扫描二维码关注公众号,回复: 5981964 查看本文章

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

猜你喜欢

转载自blog.csdn.net/tonglin12138/article/details/88636170
今日推荐