当使用传统的 makefile 风格时,每个目标都在单独的条目中定义,其中包含了该目标的依赖关系和构建规则。以下是一个示例:
edit: main.o kbd.o command.o display.o insert.o search.o files.o utils.o
cc -o edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o
main.o: main.c defs.h
cc -c main.c
kbd.o: kbd.c defs.h command.h
cc -c kbd.c
command.o: command.c defs.h command.h
cc -c command.c
display.o: display.c defs.h buffer.h
cc -c display.c
insert.o: insert.c defs.h buffer.h
cc -c insert.c
search.o: search.c defs.h buffer.h
cc -c search.c
files.o: files.c defs.h command.h
cc -c files.c
utils.o: utils.c defs.h
cc -c utils.c
而使用基于前置条件的分组风格的 makefile,可以将相同前置条件的目标放在一起,更加紧凑,如下所示:
objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
edit: $(objects)
cc -o edit $(objects)
$(objects): defs.h
kbd.o command.o files.o: command.h
display.o insert.o search.o files.o: buffer.h
这两种风格的 makefile 实现的功能是相同的,但基于前置条件的分组风格将目标和其依赖的前置条件更紧密地组合在一起,使得 makefile 更加简洁和易于维护。然而,有些人可能更喜欢传统风格的 makefile,因为它们将每个目标的相关信息放在一起,更容易理解和修改。选择使用哪种风格取决于个人偏好和项目需求。