调试makefile—.PHONY : 5 O/ Z0 ]/ J6 z& o" r9 H7 u: X y2 F
# G2 G k n. Q) w2 D+ ?4 O
1 a3 p6 b+ b" H5 X. Z/ h! ~8 a8 d操作系统:ubuntu10.04! ^( E6 ]' x$ l7 o' b
4 W1 z6 B& v- O( x
) F. Y, t' `0 `% r.PHONY是一个特殊工作目标(special target)( d) U1 T. w) P' p9 T0 _
它用来指定一个假想的工作目标,也就是说它后面的并不是一个实际文件,而且肯定要视为未更新(也就是说条件总是满足,需要处理)
; E/ b; _* r2 T# T: [ PHONY 目标并非实际的文件名:只是在显式请求时执行命令的名字。有两种理由需要使用PHONY 目标:避免和同名文件冲突(防止存在和PHONY执行目标的名称相同的文件,虽然在写比较小的makefile工程的时候看不出来.PHONY的好处,但是当面对一些大工程的时候,.PHONY则显得相当有用),改善性能。
& T- i) G# F4 }1 K+ D2 u4 D) o 如果编写一个规则,并不产生目标文件,则其命令在每次make 该目标时都执行。( V! i. ^1 [, R- v* |) ~
例如:* A8 W6 o! k" _: h! W6 j
clean:
8 ~+ t0 v% e/ l; X) } rm *.o temp1 I8 R) A$ v8 H
因为"rm"命令并不产生"clean"文件,则每次执行"make clean"的时候,该命令都会执行。如果目录中出现了"clean"文件,则规则失效了:没有
3 z+ x0 C& s' ]8 Z s& D 依赖文件,文件"clean"始终是最新的,命令永远不会执行;为避免这个问题,可使用".PHONY"指明该目标。如:$ S+ C& |7 Q2 T! ]
.PHONY : clean
8 R' h# c0 R- T j* V 这样执行"make clean"会无视"clean"文件存在与否。% \6 w5 ]: n: c
已知phony 目标并非是由其它文件生成的实际文件,make 会跳过隐含规则搜索。这就是声明phony 目标会改善性能的原因,即使你并不担心实际文件存在与否。
6 _ }( D* J/ o, r! W2 a+ l# C 完整的例子如下:, ~1 e8 R# U9 @, x% j# Y
.PHONY : clean
3 u" A2 ?9 A7 T3 S7 _) ` clean :
2 ]$ a3 u; V7 p5 v1 g rm *.o temp. T1 \: ^% J, k5 U. f
phony 目标不应是真正目标文件的依赖。如果这样,每次make 在更新此文件时,命令都会执行。只要phony 目标不是真正目标的依赖,规则的命令只有在指定此目标时才执行。
* y" J% d6 o$ o( A: } phony 目标可以有依赖关系。当一个目录中有多个程序,将其放在一个makefile 中会更方便。因为缺省目标是makefile 中的第一个目标,通常将这个phony 目标叫做"all",其依赖文件为各个程序:
0 L* X1 {5 u5 l all : prog1 prog2 prog30 ?; ?- ?2 \% {6 @
.PHONY : all7 Z7 r5 c6 q* Y# u: z! N/ O' Y
prog1 : prog1.o utils.o
q, e4 r# n7 K+ F2 f, k, k8 ^ cc -o prog1 prog1.o utils.o0 d% @# P: }) ~) W
prog2 : prog2.o9 p+ z0 o6 b% E% \$ {
cc -o prog2 prog2.o
; t. }1 Z, J$ }0 _$ E+ w2 B2 Z- f. ]4 T prog3 : prog3.o sort.o utils.o cc -o prog3 prog3.o sort.o utils.o 1 D$ K& W* f/ j+ q1 ]1 C8 S
1 U Q3 s ]/ m v
实例:9 ~. i: S, W! M: s
点击(此处)折叠或打开
# P* A5 T$ X2 J9 s/ z- test1:main.o file1.o file2.o file3.o
; }) Y: [- j) z1 ~2 d% y3 s0 ?) S( I& C - cc -o test1 main.o file1.o file2.o file3.o
- main.o:main.c
- cc -c main.c
- file1.o :file1.c
- cc -c file1.c
- file2.o :file2.c
- cc -c file2.c
- file3.o :file3.c
- cc -c file3.c
- .PHONY:test
- test:
- rm main.o file1.o file2.o /
- file3.o& D% H, a8 V b5 @
5 ]; ~& I, F1 |; O2 h% V
# V; J3 e' v/ x& V" B t. @在makefile 所在的目录下,建立一个test的文件夹,此时你输入make test 可以成功的执行删除命令 如果你把.PHONY : test 这句给删除了那么当make test时就会提示
8 B9 {, m% o) a6 q7 S. Smake: “test”是最新的。也就无法达到删除目的。 " H# D0 O- J2 R
* E8 \& Z" D: Q# `& u9 y
参考文件:$ ]0 I. X7 D: R, y
1,http://blog.csdn.net/wxdcxp/article/details/4826480
|5 ~3 ^5 r% @# ?3 q% R" I7 p. M2,http://www.360doc.com/resaveArt.aspx?articleid=293265741&isreg=1+ u! M" ], b3 O9 _4 L! Y* ?( j
- y+ H. s* a' w1 H, u. u! T; @8 u! G2 C+ u4 I' p3 W
|