makefile的规则
目标:依赖
命令
1.
mycal:add.c sub.c mul.c div.c
gcc add.c sub.c mul.c div.c -o mycal
2.
为了提高效率,避免重复编译
app:main.o add.o sub.o mul.o (终极目标)
gcc main.o add.o sub.o mul.o -o app
main.o:main.c
gcc -c main.c
add.o:add.c
gcc -c add.c
sub.o:sub.c
gcc -c sub.c
mul.o:mul.c
gcc -c mul.c
3.
简化
obj=main.o add.o sub.o mul.o
target =app
t
a
r
g
e
t
:
{target}:
target:{obj}
gcc:${obj} -o ${target}
%.o:%.c
gcc -c $< -o $@
下面可以采用模式规则,查找main.o没有则会查找模式
makefile中的自动变量
$< : 规则中的第一个依赖
$@ : 规则中的目标
$^: 规则中的所有依赖
只能在规则中的命令来使用
4.函数 wildcard
src=
(
w
i
l
d
c
a
r
d
.
/
∗
.
c
)
查
找
当
前
目
录
下
.
c
文
件
o
b
j
=
(wildcard ./*.c)查找当前目录下.c文件 obj=
(wildcard./∗.c)查找当前目录下.c文件obj=(patsubst ./%.o,./%.c,${src})把当前目录下的所有.c匹配替换成.o
5.clean规则
.PHONY:clean(声明为伪目标)
clean:
rm ${obj} ${target}
make clean直接执行目标