第一层:显式规则
目标文件:依赖文件
[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
//伪目标
.PHONY:
clean:
rm -rf hello.o hello.S hello.i hello
//使用时 make clean
//得到可执行文件: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 main.o
第二层:变量
=(替换) +=(追加) :=(恒等于)
$符号很重要
TAR = test
OBJ = circle.o cube.o main.o
CC := gcc
$(TAR):$(OBJ)
$(CC) $(OBJ) -o $(TAR)
......
第三层:隐含规则
%.c %.o//任意.c .o
*.c *.o//所有.c .o
$^ 所有的目标文件
$@所有的依赖文件
$<所有的依赖文件的第一个文件