学习目标:
掌握Makefile隐式规则,并简化Makefile脚本编写
写在前面:
Makefile有一套自动推导规则,包括根据.c自动生成.o等,利用这些规则可以极大简化脚本编写,但是建议刚开始还是要掌握规范的写法,后期熟悉了进行简化替代。
隐式规则:
原来的Makefile
#Makefile
CC=gcc
CFLAGS=-c -Wall -I ./include
RM=rm -rf
OBJ=test1.o
OBJ+=main.o
main:$(OBJ)
$(CC) $^ -o main
test1.o:test1.c
$(CC) $(CFLAGS) $+ -o $@
main.o:main.c
$(CC) $(CFLAGS) $+ -o $@
.PHONY:clean
clean:
$(RM) *.o main
1- 根据.c自动推导.o
利用该规则可以简化前面的Makefile脚本,如下:
#Makefile
CC=gcc
CFLAGS=-c -Wall -I ./include
RM=rm -rf
OBJ=test1.o
OBJ+=main.o
main:$(OBJ)
$(CC) $^ -o main
test1.o:test1.c
main.o:main.c
.PHONY:clean
clean:
$(RM) *.o main
2- 根据可执行文件及依赖的目标.o文件自动推导其他规则
这样就只需要写上:可执行文件:依赖.o就可以了,剩余的Makefile自动推导。
注意:可执行文件名必须和依赖.o文件中的某一个文件名一致,例如有个main.o,可执行文件可为main。
简化后的Makefile文件
#Makefile
CC=gcc
CFLAGS=-c -Wall -I ./include
RM=rm -rf
OBJ=test1.o
OBJ+=main.o
main:$(OBJ)
.PHONY:clean
clean:
$(RM) *.o main