在Linux Makefile中,规则是用于指定如何生成目标文件(target)的一组命令
目标(Target):规则的目标是要生成的文件。通常,这是一个可执行文件、库文件或者其他类型的输出文件。
依赖(Dependencies):规则的依赖是生成目标所需的输入文件。这些文件可以是源代码文件、头文件、其他生成的文件等。
命令(Commands):规则的命令是用于生成目标的一系列shell命令。每个命令都应该以制表符(Tab)开头。
下面是一个简单的Makefile示例,用于编译一个C程序:
# 定义编译器和编译选项
CC = gcc
CFLAGS = -Wall -g
# 定义目标文件和依赖文件
TARGET = my_program
OBJS = main.o utils.o
# 默认规则,用于生成目标文件
all: $(TARGET)
# 规则:生成目标文件
$(TARGET): $(OBJS)
$(CC) $(CFLAGS) -o $@ $^
# 规则:生成.o文件
%.o: %.c
$(CC) $(CFLAGS) -c $< -o $@
# 清理规则,用于删除生成的文件
clean:
rm -f $(TARGET) $(OBJS)
在这个示例中,我们定义了一个名为my_program
的目标文件,它依赖于main.o
和utils.o
两个.o文件。我们还定义了一个默认规则all
,用于生成目标文件。此外,我们还定义了一个用于生成.o文件的模式规则,以及一个用于清理生成文件的规则。
要使用这个Makefile,只需将其保存为Makefile
或makefile
,然后在命令行中运行make
命令。这将根据Makefile中的规则生成目标文件。