1、makefile中有.PHONY修饰clean,为什么需要.PHONY?
.PHONY: clean
clean:
-rm *.o
先看看正常的makefile使用:
hello: hello.c
gcc $^ -o $@
可以看出,顶格写的hello是需要生成的目标文件。那假如当前目录下已经存在hello文件,再一次执行makefile会怎么样呢?答案是,没有执行成功,会报错。
这种情况怎么办?那就是在上面使用.PHONY: hello完成修饰。告知系统hello是一个伪目标,当目标文件已经存在目录下时,不需要处理,直接执行下面的脚本。
因此修饰clean的作用就是告诉系统clean是一个伪目标。避免出现clean的文件在当前目录下,执行makefile报错。当然一般也不太可能存在clean文件,一般clean标志默认就是使用清文件的标志。By the way,-rm *.o前面的横杆是什么意思?出现错误退出,继续往下运行。
2、make -C dir/ clean 为什么需要加-C ?
makefile文件没有存放在当前目录下,而是在dir目录下
3、makefile文件是不是必须命名成makefile(不管大小写) ?
答案是否定的。取名成makefile当然好了,比较规范。但是也可以不按常理出牌。
加-f选项。如make -f rule.debug,rule.debug就是makefile文件。