[转]makefile__PHONY 目标

[转]makefile__PHONY 目标

http://blog.chinaunix.net/u1/35496/showart_273030.html
makefile__PHONY 目标
发表于: 2007-04-08,修改于: 2007-04-08 12:22

1. 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"将可以将三个程序都生成了。d
  当一个phony 目标是另一个的依赖,其作用相当于子程序,例如:
  .PHONY: cleanall cleanobj cleandiff
  cleanall : cleanobj cleandiff
          rm program
  cleanobj :
          rm *.o
  cleandiff :
          rm *.diff

2. 自动变量($^ $< $@)的应用

Makefile 有三个非常有用的变量,分别是$@、$^、$<。代表的意义分别是:
$@--目标文件,
$^--所有的依赖文件,
$<--第一个依赖文件。

CC = gcc
OBJ = main.o mytool1.o mytool2.o

main: $(OBJ)
    $(CC) -o $@ $^

main.o: main.c mytool1.h mytool2.h
    $(CC) -c $<
mytool1.o: mytool1.c mytool1.h
    $(CC) -c $<
mytool2.o: mytool2.c mytool2.h
    $(CC) -c $<

.PHONY: clean
clean:
    rm -f main $(OBJ)

=========分割线=========
gnu makefile的manual:
http://www.gnu.org/software/make/manual/make.html#Phony-Targets


你可能感兴趣的:([转]makefile__PHONY 目标)