Makefile是一种编译控制文件,广泛用于项目的自动化构建。它定义了一系列的规则来指导构建的过程。
通过Makefile,开发者可以轻松管理大型项目的编译链接、清理等任务。
本文将从Makefile的基础用法讲起,逐步深入到更高级的应用,为你呈现一个全面而详细的Makefile使用手册。
一个最简单的Makefile包含规则,规则由目标(target)、依赖(dependencies)和命令(commands)三部分组成:
target: dependencies
commands
命令前的Tab键是必须的。下面是一个简单的示例:
hello: hello.c
gcc -o hello hello.c
在Makefile中声明变量可以使得我们的代码更加简洁。
CC=gcc
CFLAGS=-std=c99
LDFLAGS=
OBJ=main.o utils.o
app: $(OBJ)
$(CC) -o app $(OBJ) $(LDFLAGS)
main.o: main.c
$(CC) $(CFLAGS) -c main.c
utils.o: utils.c utils.h
$(CC) $(CFLAGS) -c utils.c
模式规则可以减少我们重复相同命令的工作量。
%.o: %.c
$(CC) $(CFLAGS) -c $<
$< 是自动变量之一,代表依赖列表中的第一项。
Makefile提供了一系列自动化变量,它们在规则的命令中非常有用:
Makefile中内置了许多函数,用以执行字符串操作、文件操作等。
例如,获取源文件列表:
SRC=$(wildcard *.c)
OBJ=$(patsubst %.c,%.o,$(SRC))
Makefile也支持条件判断,这在不同环境需要执行不同命令时非常有用。
ifeq ($(OS),Windows_NT)
RM=del /Q
else
RM=rm -f
endif
clean:
$(RM) *.o
对于大型项目,组织多个Makefile是一种好方法。
# 在子Makefile中
include config.mk
通过定义可以重用的函数,你可以使你的Makefile变得更加强大和灵活。
define run-cc
$(CC) $(CFLAGS) -o $@ $^
endef
app: $(OBJ)
$(call run-cc)
定义一个规则来批量处理多个文件。
FILES := file1 file2 file3
all: $(FILES)
$(FILES):
touch $@
伪目标不代表实际的文件,它只是一个动作的名称。
.PHONY: clean
clean:
rm -f *.o app
你可以使用make --debug或添加注释来帮助调试Makefile。
app: main.o utils.o
# 这是一个链接的命令
$(CC) -o app main.o utils.o
Makefile是构建自动化的强大工具,既可以简化小型项目的构建流程,也能够灵活管理大型应用程序的复杂构建系统。
通过本文的详细论述和丰富示例,您应该能够基本掌握Makefile的各项技能,并在实际项目中加以应用。
关注【一起学嵌入式】,回复“加群”进技术交流群。
觉得文章不错,点击“分享”、“赞”、“在看” 呗!