您的位置:首页 > 其它

Makefile中的.PHONY

2014-08-15 17:47 357 查看
/PHONY 来显示的指名一个目标是伪目标,有两个作用一个是改善性能,另外一个是来避免冲突。

例如我写了这样一个Makefile

[cpp] view
plaincopy

test1:main.o file1.o file2.o file3.o

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

在makefile 所在的目录下,建立一个test的文件夹,此时你输入make test 可以成功的执行删除命令

如果你把.PHONY : test 这句给删除了那么当make test时就会提示

make: “test”是最新的。也就无法达到删除目的。所以为了避免和文件重名,我们可以使用.PHONY来指名该目标是个伪目标

others:

Makefile有三个非常有用的变量。分别是$@,$^,$<代表的意义分别是:

$@--目标文件,$^--所有的依赖文件,$<--第一个依赖文件。

下面例子把所有的.c 文件编译成.o 文件:

%.o:%.cpp

$(CC) -c $^ -o $@
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: