自动化变量:不用定义且会随着上下程序的不同而发生变化的变量
一下是一些自动化变量的基本用法:
最常用的三个:
$@: 表示所有目标
$<: 表示第一个依赖文件,如果依赖模式是%,那么它就表示一系列文件(%为通配符,类似Linux的*)
$^:表示所有依赖
用以下例子来表明自动化变量的作用。
原Makefile文件
hello:hello.o main.o
gcc hello.o main.o -o hello
hello.o:hello.c
gcc -c hello.c -o hello.o
main.o:main.c
gcc -c main.c -o main.o
clean:
rm -rf *.o hello
优化1:用变量来代替依赖文件
var:=hello.o main.o
hello:$(var)
gcc $(var) -o hello
hello.o:hello.c
gcc -c hello.c -o hello.o
main.o:main.c
gcc -c main.c -o main.o
clean:
rm -rf *.o hello
优化2:使用通配符%,和自动化变量$@ $<来替代依赖和目标
var:=hello.o main.o
hello:$(var)
gcc $(var) -o hello
%.o:%.c
gcc -c $< -o $@
clean:
rm -rf *.o hello
优化3:使用自动化变量$^表示所有依赖
var:=hello.o main.o
hello:$(var)
gcc $^ -o hello
%.o:%.c
gcc -c $< -o $@
clean:
rm -rf *.o hello