make解释器提供了一系列的函数供makefile调用
在makefile中支持自定义函数实现,并调用执行
通过define关键字实现自定义函数
实验:
.PHONY : test
define func1
@echo "My name is $(0)"
endef
define func2
@echo "My name is $(0)"
@echo "Param 1 => $(1)"
@echo "Param 2 => $(2)"
endef
test :
$(call func1) #在规则中调用 func1
$(call func2, D.T.Software, delphi_tang) #在规则中调用 func2
mhr@ubuntu:~/work/makefile1$ make
My name is func1
My name is func2
Param 1 => D.T.Software
Param 2 => delphi_tang
mhr@ubuntu:~/work/makefile1$
深入理解自定义函数:
自定义函数是一个多行变量,无法直接调用
自定义函数是一种过程调用,没有任何的返回值
自定义函数用于定义命令集合,并应用于规则中
自定义函数调用深度理解:
.PHONY : test
define func1
@echo "My name is $(0)"
endef
# 调用 func1 初始化 变量var,可以这样操作吗?并没有在规则中调用,func1 调用成功了吗?
# 肯定是不会成功的,自定义函数调用必须在规则中使用,如例1
var := $(call func1)
test :
@echo "var => $(var)"
// 函数没有被调用,这里打印的是 func1这个多行变量的值: @echo "My name is $(0)"
// 如果是 函数调用 打印的应该是 :My name is func1
mhr@ubuntu:~/work/makefile1$
mhr@ubuntu:~/work/makefile1$ make
var => @echo My name is func1
mhr@ubuntu:~/work/makefile1$
说明:实验结果打印了
var => @echo My name is func1
函数被调用了吗? 函数肯定没有被调用,这仅仅是 func1这个多行变量的值。define 是用来定义多行变量的,只不过说 多行变量可以在call 的作用下当作一个自定义函数来使用,这个使用又是有限制的,必须在规则中使用,所以这个位置 这样写 :
var := $(call func1)
是不会起到函数调用的作用的,这样写仅仅是把 func1 当做一个变量来处理了。自定义函数的本质就是多行变量。
实验:
.PHONY : test
define func1
@echo "My name is $(0)"
endef
new := $(func1)
test :
@echo "new => $(new)"
mhr@ubuntu:~/work/makefile1$ make
new => @echo My name is
mhr@ubuntu:~/work/makefile1$
说明:打印出来 new 的值没有函数名,所以 对比上一个实验可以知道,call 的作用就是将实参替换到函数体当中对应的位置。如 new := $(func1) ,并没有使用call,所以说并不会将这个变量里面的相应位置的地方换成实参。
实验:call 处理的对象是多行变量
待更新。。。。。