温馨提示×

Linux Makefile中的规则如何编写

小樊
82
2024-09-03 11:49:56
栏目: 智能运维

在Linux Makefile中,规则是用于指定如何生成目标文件(target)的一组命令

  1. 目标(Target):规则的目标是要生成的文件。通常,这是一个可执行文件、库文件或者其他类型的输出文件。

  2. 依赖(Dependencies):规则的依赖是生成目标所需的输入文件。这些文件可以是源代码文件、头文件、其他生成的文件等。

  3. 命令(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.outils.o两个.o文件。我们还定义了一个默认规则all,用于生成目标文件。此外,我们还定义了一个用于生成.o文件的模式规则,以及一个用于清理生成文件的规则。

要使用这个Makefile,只需将其保存为Makefilemakefile,然后在命令行中运行make命令。这将根据Makefile中的规则生成目标文件。

0