编写 Makefile 的过程如下:
- 定义变量:定义编译器、编译选项等变量。
- 定义目标文件:定义目标文件名。
- 定义源文件:定义所有的源文件。
- 定义规则:定义将每个源文件编译成目标文件的规则。
- 定义伪目标:定义清除目标文件和其他中间文件的伪目标。
下面是一个示例 Makefile,假设每个目录都有一个以 .c
结尾的源文件需要被编译成对应的可执行文件:
CC = gcc
CFLAGS = -Wall -Wextra -Werror
SRCDIRS = src1 src2 src3
TARGETS := $(patsubst %, %/target, $(SRCDIRS))
all: $(TARGETS)
%/target: %/*.c
$(CC) $(CFLAGS) $^ -o $@
.PHONY: clean
clean:
find . -name target -type f -delete
CC
定义了使用的编译器,这里使用 gcc。CFLAGS
定义了编译选项,这里开启了一些警告选项。SRCDIRS
定义了所有源文件所在的目录。TARGETS
是所有可执行文件的列表,使用了 patsubst 函数将源文件路径替换成可执行文件路径。all: $(TARGETS)
表示 all 依赖于所有的可执行文件,可以通过在命令行输入$ make
来生成所有的可执行文件。%/target: %/*.c
表示规则,将一个目录下的所有.c
文件编译成对应的可执行文件,并存储到该目录下的名为target
的文件中。.PHONY: clean
表示 clean 是一个伪目标,不是真正的文件,可以通过在命令行输入$ make clean
来删除所有的可执行文件。其中使用了find
命令来查找名为target
的文件并删除。