makefile是一个Linux程序员必须掌握的工具,makefile用于项目管理当中使得项目编译十分便捷,下面来介绍makefile使用。
目录
makefile使用
要初步使用makefile,我们只需掌握下面三个方面。
一个规则:
目标:依赖条件
(一个tab缩进)+命令
两个函数
src = $(wildcrad *.c)——找到当前文件下所以的 .c 文件赋值给src变量
obj = $(patsubst %.c, %.o, $(src))——把src变量中所以后缀名为 .c 替换成 .o
三个自动变量
$@——在规则命令中表示目标
$<——表示规则中第一个依赖条件
$^ ——表示所以依赖条件
makefile举例
如果你没有接触过makefile,通过上面的讲述你可能一脸迷茫,不用担心,下面通过举例就能使你茅塞顿开。
如果我们想要gcc将一个c文件编译成可执行程序,我们会怎样做,我以heelo.c举例。
gcc hello.c -o a.out (将heelo.c编译生成啊a.out)
——这个大家都不陌生,那么makefile需要怎么做呢?很简单
vi makefile (先创建一个makefile)
a.out:hello.c gcc hello.c -o a.out
a.out就是我们的目标:hello.c为依赖条件
然后第二行开始就是我们的命令(命令之前需要一个TAB缩进)
通过上这个例子是不是理解了第一条规则呢,下面让我们接着介绍两个函数。
wlidcard——函数就是把文件复制给变量,比如当我们一个程序当中有很多c文件时,就可以把所以c文件赋值给我们定义的变量。
patsubst——函数就是把对应的文件进行一个批量替换。
当我们需要编译一下程序并生成对于的.o文件时、
我们如果使用常规做法就是——
gcc -c div.c -o div.o
gcc -c sub.c -o sub.o
gcc -c sum.c -o sum.o
gcc -c mul.c -o mul.o
gcc -c main.c -o mian.o
分别生成对于的.o文件然后在通过.o生成可执行文件
gcc div.o sub.o sum.o mul.o main.o -o a.out
下面让我们来写makefile
a.out:main.o sub.o div.o sum.o mul.o #(makefile以第一条命令为终极目标) gcc main.o sub.o div.o sum.o mul.o -o a.out main.o:main.c gcc -c main.c -o main.o div.o:div.c gcc -c div.c -o div.o sum.o:sum.c gcc -c sum.c -o sum.o sub.o:sub.c gcc -c sub.c -o sub.o mul.o:mul.c gcc -c mul.c -o mul.o #(这个是对应的makefile) 下面我们使用函数对其改进 src = $(wildcard *.c) #(main.c div.c sum.c sub.c div.c) obj = $(patsubst %.c,%.o,$(src)) #(main.o sum.o sub.o div.o) a.out:$(obj) gcc $(obj) -o a.out main.o:main.c gcc -c main.c -o main.o div.o:div.c gcc -c div.c -o div.o sum.o:sum.c gcc -c sum.c -o sum.o sub.o:sub.c gcc -c sub.c -o sub.o mul.o:mul.c gcc -c mul.c -o mul.o #(注:直接复制到linux环境需要从新tab缩进一下,否则出错)
之后我们就可以引入自动变量了,
$@——在规则命令中表示目标
$<——表示规则中第一个依赖条件
$^ ——表示所以依赖条件
src = $(wildcard *.c) obj = $(patsubst %.c,%.o,$(src)) ALL:a.out %.o:%.c gcc -c $< -o $@ a.out:$(obj) gcc $(obj) -o a.out clean: -rm -rf *.o #(注:直接复制到linux环境需要从新tab缩进一下,否则出错)
ALL——所跟的就是终极目标a.out。
clean:(执行 make clean)
-rm -rf 是删除所以 .o 文件
下面让我们来做一个练习。
当我们需要编译一个文件下有很多的c文件都要生成其对应的可执行文件时。
我们需要分别去执行gcc执行5次。
gcc test.c -o test (编译test.c生成test) gcc test1.c -o test1 gcc test2.c -o test2 gcc test3.c -o test3 gcc test4.c -o test4
使用makefile
src = $(wildcard *.c) #(test.c test1.c test2.c test3.c test4.c) obj = $(patsubst %.c, %, $(src)) #(相当于将上面对于替换成 test test1 test2 test3 test4) par = -Wall -g ALL:$(obj) %:%.c gcc $< -o $@ $(par) clean: -rm -rf $(obj) .PHONY: clean ALL #(注:直接复制到linux环境需要从新tab缩进一下,否则出错)
par——就是变量 $(par)就是取变量值, gcc $< -o $@ $(par) 相当于 gcc $< -o $@ -Wall -g
.PHONY:为伟目标——不管条件是否满足都会执行clean
makefile一些parameter使用技巧
模拟执行
make -n
make clean -n
如果没有以makefile命名
make -f +名称