阅读量:0
在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中的规则生成目标文件。