(1)普通變量
如:
obj=main.o add.o sub.o mul.o div.o //將后面的值賦值給obj,obj就是一個普通變量
target=zsx? //將zsx賦值給target
makefile中已經定義的一些普通變量(通常格式都是大寫,類似環境變量,它們都是普通變量,直接賦值即可,任意類型皆可):CC,其值為gcc或cc(cc就是gcc,完全等價),且用戶還可以修改這些值。
(2)自動變量
$<: 規則中的第一個依賴? ? ?$@: 規則中的目標? ? ?$^: 規則中的所有依賴
注意:這些變量只能在規則的命令中使用
(3)舉例
則通過使用自動變量和普通變量,可以簡化makefile的書寫,下面舉例說明。依然使用上篇的文章的例子。
[root@localhost src]# vim makefile
obj=main.o add.o sub.o mul.o div.o? //普通變量
target=zsx? ?//普通變量
$(target):$(obj)
? ? ? ? $(CC) -ggdb3 $^ -o $@? ? ?//自動變量只能使用在命令中
main.o:main.c
? ? ? ? $(CC) -pedantic -pipe -Wall -c $^ -o $@ -I ../include? ?//單獨拿出來 是因為其需要指明頭文件,而頭文件在另一個目錄中
%.o:%.c
? ? ? ? $(CC) -pedantic -pipe -Wall -c $< -o $@
[root@localhost src]# ls
add.c ?div.c ?main.c ?makefile ?mul.c ?sub.c
[root@localhost src]# make
cc -pedantic -pipe -Wall -c main.c -o main.o -I ../include
cc -pedantic -pipe -Wall -c add.c -o add.o
cc -pedantic -pipe -Wall -c sub.c -o sub.o
cc -pedantic -pipe -Wall -c mul.c -o mul.o
cc -pedantic -pipe -Wall -c div.c -o div.o
cc -ggdb3 main.o add.o sub.o mul.o div.o -o zsx
[root@localhost src]# ls
add.c ?add.o ?div.c ?div.o ?main.c ?main.o ?makefile ?mul.c ?mul.o ?sub.c ?sub.o ?zsx
[root@localhost src]# ./zsx
sum = 26
?