Makefile .PHONY
来源:互联网 发布:linux vi查看文件内容 编辑:程序博客网 时间:2024/06/05 11:14
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)
- Makefile .PHONY
- makefile .PHONY
- Makefile .PHONY
- Makefile中的PHONY 目标
- Makefile里的PHONY
- (makefile).PHONY 伪目标
- Makefile中的PHONY
- makefile中的.PHONY
- makefile .PHONY 伪目标
- Makefile中的.PHONY
- makefile 中的PHONY
- makefile 中的PHONY
- makefile中的phony使用
- Makefile(1) --- .PHONY
- Makefile中的.PHONY
- Makefile 中的.PHONY
- Linux之Makefile(.PHONY)
- makefile里PHONY总结
- Smarty实例教程(2)
- 有关Navigation的研究
- 如何做好网站开发项目需求分析
- 测试
- 什么是CDN?
- Makefile .PHONY
- (转)C++中extern “C”含义深层探索
- dxflib库的编译及使用
- 系统分析员基本功
- 状态机简介
- 好书
- o3d中正反两个面都可以看见贴图
- BSP包的克隆
- 安装DM355工具链,网友整理,比较完整