编写Makefile将各个目录下的.c文件编译成各自的可执行文件

编写 Makefile 的过程如下:

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

下面是一个示例 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 的文件并删除。

猜你喜欢

转载自blog.csdn.net/FLM19990626/article/details/130983397
今日推荐