编写Makefile将一个目录下的所有 .c 文件编译成可执行文件

编写 Makefile 的过程如下:

  1. 定义变量:定义编译器、编译选项等变量。
  2. 定义目标文件:定义目标文件名。
  3. 定义源文件:定义所有的源文件。
  4. 定义规则:定义将每个源文件编译成目标文件的规则。
  5. 定义伪目标:定义清除目标文件和其他中间文件的伪目标。

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 来删除所有的可执行文件。

猜你喜欢

转载自blog.csdn.net/FLM19990626/article/details/130983496