Makefile 快速入门
makefile
示例
准备文件如下:
fun1.c
#include<stdio.h>
void fun1()
{
printf("fun1");
}
fun2.c
#include<stdio.h>
void fun1()
{
printf("fun1");
}
main.c
int main()
{
fun1();
fun2();
return 0;
}
目标:将这3个C文件编译,链接成一个可执行文件
命令行的编译方法
首先,分别将C文件编译成中间文件
gcc -c fun1.c -o fun1.o
gcc -c fun2.c -o fun2.o
gcc -c main.c -o main.o
然后将中间文件进行链接
gcc main.o fun1.o fun2.o -o app
虽然可以实现,但如果项目文件多起来,就要输入很多很长的命令
编写第一个Makefile
在目录下创建文件 Makefile,内容遵循以下格式:
目标文件:源文件
(Tab缩进)命令
app: main.o fun1.o fun2.o
gcc main.o fun1.o fun2.o -o app
main.o: main.c
gcc -c fun1.c -o fun1.o
fun1.o: fun1.c
gcc -c fun2.c -o fun2.o
fun2.o: fun2.c
gcc -c main.c -o main.o
然后执行指令:make,即可编译链接生成可执行文件
Makefile的简化
初步简化
通过变量和模式规则,减少输入
obj = main.o fun1.o fun2.o
target = app
CC = gcc
$(target): $(obj)
$(CC) $(obj) -o $(target)
%.o: %.c
$(CC) -c $< -o $@
%.o %.c 即所有的.o、.c后缀的文件
自动变量\(<、\)@,依赖文件和目标
缺点:obj要一个一个输入
进一步简化
-
wildcard
扩展通配符,表示搜索指定文件,比如
src = $(wildcard ./*.c)
代表在当前目录下搜索所有.c文件,然后赋值给src -
patsubst
替换通配符,
obj = \((patsubst %.c,%.o,\)(src))
代表将src中所有的.c替换成.o -
make clean
通过编写.PHONY clean,在执行make clean时可以删除中间文件
src = $(wildcard ./*.c)
obj = $(patsubst %.c, %.o, $(src))
target = app
CC = gcc
$(target):$(obj)
$(CC) $(obj) -o $(target)
%.o:%.c
$(CC) -c $< -o $@
.PHONY: clean
clean:
rm -rf $(obj)