编写 Makefile 的过程如下:
- 定义变量:定义编译器、编译选项等变量。
- 定义目标文件:定义目标文件名。
- 定义源文件:定义所有的源文件。
- 定义规则:定义将每个源文件编译成目标文件的规则。
- 定义伪目标:定义清除目标文件和其他中间文件的伪目标。
CC = gcc
CFLAGS = -Wall -Wextra -Werror
SOURCES := $(wildcard *.c)
TARGETS := $(patsubst %.c, %, $(SOURCES))
all: $(TARGETS)
%: %.c
$(CC) $(CFLAGS) $< -o $@
.PHONY: clean
clean:
rm -f $(TARGETS)
CC
定义了使用的编译器,这里使用 gcc。CFLAGS
定义了编译选项,这里开启了一些警告选项。SOURCES
是所有源文件的列表,使用了通配符*.c
可以找到当前目录下所有以.c
结尾的文件。TARGETS
是所有可执行文件的列表,使用了 patsubst 函数将源文件路径替换成可执行文件路径(去除了文件扩展名)。all: $(TARGETS)
表示 all 依赖于所有的可执行文件,可以通过在命令行输入$ make
来生成所有的可执行文件。%: %.c
表示规则,将一个.c
文件编译成对应的可执行文件,并存储到与源文件同名的文件中。.PHONY: clean
表示 clean 是一个伪目标,不是真正的文件,可以通过在命令行输入$ make clean
来删除所有的可执行文件。