https://www.bilibili.com/video/av58382901
第一层:显式规则
1.创建文本,取名Makefile
2.语法:#是注释
3.显示规则
目标文件:依赖文件
TAB 指令
hello:hello.o
gcc hello.o -o hello
hello.o:hello.S
gcc -c hello.S -o hello.o
hello.S:hello.i
gcc -S hello.i -o hello.S
hello.i:hello.c
gcc -E hello.c -o hello.i
4.第一个目标文件是最终目标,即hello
5.伪目标,没有依赖文件,只是一个操作;
.PHONY:
cleanall:
rm -rf hello.o hello.i hello.S hello
clean:
rm -rf hello.o hello.i hello.S
6.得到可执行文件test,省去预编译 汇编
test:circle.o cube.o main.o
gcc circle.o cube.o main.o -o test
circle.o:circle.c
gcc -c circle.c -o circle.o
cube.o:cube.c
gcc -c cube.c -o cube.o
main.o:main.c
gcc -c main.c -o mian.o
.PHONY
clearall:
rm -rf circle.o cube.o main.o test
clear:
rm -rf circle.o cube.o main.o
第二层:变量
1.变量 =(替换) +=(追加) :=(恒等于)
使用变量$(变量名)替换
TAR = test
OBJ = circle.o cube.o main.o
CC := gcc
$(CC):$(OBJ)
$(CC) $(OBJ) -o $(OBJ)
circle.o:circle.c
$(CC) -c circle.c -o circle.o
cube.o:cube.c
$(CC) -c cube.c -o cube.o
main.o:main.c
$(CC) -c main.c -o mian.o
.PHONY
clearall:
rm -rf $(OBJ) $(OBJ)
clear:
rm -rf $(OBJ)
第三层:隐含规则
1.隐含规则,%.c %.o表示任意的.c.o文件;.c.o表示所有的.c.o文件;
当存在100个文件?
TAR = test
OBJ = circle.o cube.o main.o
CC := gcc
$(TAR):$(OBJ)
$(CC) $(OBJ) -o $(TAR)
%.o:%.c
$(CC) -c %.c -o %.o
.PHONY
clearall:
rm -rf $(OBJ) $(OBJ)
clear:
rm -rf $(OBJ)
第四层:通配符
1. @ 所 有 目 标 文 件 ; @所有目标文件; @所有目标文件;^所有依赖文件;$<所有依赖文件的第一个文件
TAR = test
OBJ = circle.o cube.o main.o
CC := gcc
RMRF := rm -rf
$(TAR):$(OBJ)
$(CC) $@ -o $^
%.o:%.c
$(CC) -c %.c -o %.o
.PHONY
clearall:
$(RMRF) $(OBJ) $(TAR)
clear:
$(RMRF) $(OBJ)