假如你想生成的最终文件的名字就叫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