makefile 中的有两种变量: 延时变量, 立即变量.
前者在这个变量使用时才扩展, 即当真正使用时这个变量的值才确定.
后者在定义这个变量时,它的值就确定了.
延时变量用 =, ?=, 定义, 或用define 定义
如:
GCC = arm-linux-
GCC ?= arm-linux-
注意 ?= 用来定义第一次出现的延时变量.
:= 用来定义立即变量,前面的变量不能使用后面的变量,只能使用前面已定义好了的变量
GCC := arm-linux-
makefile中的内部变量:
$@ 扩展为当前规则的目标文件名;
$< 扩展为当前规则依赖文件列表中的第一个依赖文件;
$? 扩展为所有的修改日期比当前规则的目标文件的创建日期更晚的依赖文件,该值只有在使用显式规则时才会被使用;
$* 扩展成当前规则中目标文件和依赖文件共享的文件名,不含扩展名;
$^ 扩展为整个依赖文件的列表 ( 除掉了所有重复的文件名 ) 。
$(<F) 扩展为当前规则依赖文件列表中的第一个依赖文件名(不含路径);
$(<D) 扩展为当前规则依赖文件列表中的第一个依赖文件的路径;
本文介绍了Makefile中的两种变量类型:延时变量和立即变量,并解释了它们的定义方式及使用场景。同时,还详细说明了Makefile内部变量的功能,包括$@、$<、$?、$* 和 $^等。
1416

被折叠的 条评论
为什么被折叠?



