makefile中的all和.PHONY的作用(主要在于自动删除中间文件)

假如你想生成的最终文件的名字就叫APP,而且想删除中间生成的文件,则makefile可以这样写:

OBJ= app1.o app2.o

CC = gcc

all: APP clean

APP: $(OBJ)    # 这一行不能省,要不然还没生成APP 所有.o文件就已经被删除了

       $(CC)  -o $@ $(OBJ)   # 这一行不写也不会出错,自动推导的

app1.o:app1.c app1.h    

       $(CC) -g $<           #这里 -g是为了生成调试信息

app2.o:app2.c app2.h

       $(CC) -g $<

.PHONY:clean

clean:

       rm $(OBJ)

上面所有的代码是测试无误的,上面的 $< 、 $@  ,另外还有个$^,这三个符号分别表示:第一个依赖文件、目标文件、所有依赖文件. 另外还可以参考这里http://blog.sina.com.cn/s/blog_5f1761850100p37b.html

你可能感兴趣的:(makefile中的all和.PHONY的作用(主要在于自动删除中间文件))