Makefile语法
>
与>>
的区别
在shell中
‘>’ 为创建: echo “hello shell” > out.txt
‘>>’ 为追加:echo “hello shell” >> out.txt
当out.txt 文本不存在时,'>'与‘>>’都会默认创建out.txt文本,并将hello shell 字符串保存到out.txt中
当out.txt文本存在时,‘>’会将out.txt文本中的内容清空,并将hello shell 字符串存入
而‘>>’会将 hello shell追加保存到out.txt的末尾
:
后面为依赖文件
EXE=main
CC=gcc
OBJ=main.o abc.o xyz.o
CFLAGS=-g
$(EXE):$(OBJ)
$(CC) $^ -o $@
clean:
rm $(EXE) $(OBJ) -f
变量EXE,CC,OBJ分别代指目标程序名,编译器名,目标文件名。CFLAGS是C编译选项,它会附加在每条编译命令(gcc -c)之后。$(EXE)是对变量的引用,$^代指所有的依赖项——即$(OBJ),$@代指目标项——即$(EXE)。
该命令等价于:$(CC) $(OBJ) -o $(EXE)。
$(shell ...)
其作用是获取shell命令执行的结果
wildcard
扩展通配符,如匹配所有.c文件:$(wildcard *.c)