当前位置:   article > 正文

makefile中的all和.PHONY的作用_phony :=all

phony :=all

makefile中的 all和 .PHONY 的作用

 

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

main1.c:

#include<stdio.h>

int main(void)

{

    printf("main1n");

}

main2.c:

#include<stdio.h>

int main(void)

{

    printf("main2n");

}

【分析】:这里需要生成两个可执行文件main1main2(两个目标)。由于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仍然存在,怎么回事呢                             

原来这里的目标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 中的PHONY


PHONY 目标
  PHONY 目标并非实际的文件名:只是在显式请求时执行命令的名字。有两种理由需要使用PHONY 目标:避免和同名文件冲突,改善性能。
  如果编写一个规则,并不产生目标文件,则其命令在每次make 该目标时都执行。
  例如:
  clean:
  rm *.o temp
  因为"rm"命令并不产生"clean"文件,则每次执行"make clean"的时候,该命令都会执行。如果目录中出现了"clean"文件,则规则失效了:没有依赖文件,文件"clean"始终是最新的,命令永远不会执行;为避免这个问题,可使用".PHONY"指明该目标。如:
  .PHONY : clean
  这样执行"make clean"会无视"clean"文件存在与否。

  已知phony 目标并非是由其它文件生成的实际文件,make会跳过隐含规则搜索。这就是声明phony 目标会改善性能的原因,即使你并不担心实际文件存在与否。
  完整的例子如下:
  .PHONY : clean
  clean :
          rm *.o temp
  phony 目标不应是真正目标文件的依赖。如果这样,每次make在更新此文件时,命令都会执行。只要phony 目标不是真正目标的依赖,规则的命令只有在指定此目标时才执行。

  phony 目标可以有依赖关系。当一个目录中有多个程序,将其放在一个makefile 中会更方便。因为缺省目标是makefile 中的第一个目标,通常将这个phony 目标叫做"all",其依赖文件为各个程序:
  all : prog1 prog2 prog3
  .PHONY : all
  prog1 : prog1.o utils.o
           cc-o prog1 prog1.o utils.o
  prog2 : prog2.o
           cc-o prog2 prog2.o
  prog3 : prog3.o sort.o utils.o
           cc-o prog3 prog3.o sort.o utils.o

  这样,使用"make"将可以将三个程序都生成了。
  当一个phony 目标是另一个的依赖,其作用相当于子程序,例如:
  .PHONY: cleanall cleanobj cleandiff
  cleanall : cleanobj cleandiff
           rmprogram
  cleanobj :
           rm*.o
  cleandiff :
           rm*.diff

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/640981
推荐阅读
相关标签
  

闽ICP备14008679号