Bootstrap

Makefile 之 自动化变量


    作用范围只在这条规则以及连带规则中,所以其值也只在作用范围内有效。而不会影响规则链以外的全局变量的值。


    "$@" 表示目标的集合,就像一个数组,"$@"依次取出目标,并执于命令。


    "$<"和"$@"则是自动化变量,

    "$<"表示所有的依赖目标集(也就是"foo.c bar.c"),

    "$@"表示目标集(也就是"foo.o bar.o")。


    %.o : %.c
    $(CC) -c $(CFLAGS) $(CPPFLAGS) $< -o $@

    其中,"$@"表示所有的目标的挨个值,"$<"表示了所有依赖目标的挨个值。这些奇怪的变量我们叫"自动化变量".


    "$@ 扩展成当前规则的目的文件名,
    "$< 扩展成依靠列表中的第一个依靠文件,
    "$^ 扩展成整个依靠的列表(除掉了里面所有重复的文件名)。利用这些变量,
    "自动环变量“$?”在这里表示依赖文件列表中被改变过的所有文件。


    '$@  表示目标文件
    '$^  表示所有的依赖文件
    '$<  表示第一个依赖文件
    '$?  表示比目标还要新的依赖文件列表

;