函数定义与调用
1. makefile中支持函数的概念
- make解释器提供了一系列的函数供makefile调用
- 在makefile中支持自定义函数实现,并调用执行
- 通过define关键字实现自定义函数示例1--函数定义
define func1 @echo "my name is $(0)"endef复制代码
define func2 @echo "my name is $(0)" @echo "param1 => $(1)" @echo "param2 => $(2)"endef复制代码
示例1--函数调用
test : $(call func1) $(call func2, value1)复制代码
2. 深入理解自定义函数
- 自定义函数是一个多行变量,无法直接调用,需要使用call进行调用
- 自定义函数是一种过程调用,没有任何的返回值
- 自定义函数用于定义命令集合,并应用于规则中 示例2--自定义函数的应用
define func1 @echo "my name is $(0)"endefvar1 := $(call func1)var11 := $(func1)test : @echo "var1 => $(var1)" @echo "var11 => $(var11)"复制代码
3. make解释器中的预定义函数
- make的函数提供了处理文件名,变量和命令的函数
- 可以在需要的地方调用函数来处理指定的参数
- 函数在调用的地方被替换为处理结果
预定义函数的调用方法:
var := $(func_name arg1,arg2,...)复制代码
说明: var表示返回值,func_name表示函数名,arg1,arg2表示函数实参
示例3--预定义函数调用
var := $(abspath ./)test : @echo "var => $(var)"复制代码
自定义函数和预定义函数的本质区别:
- makefile中不支持真正意义上的自定义函数
- 自定义函数的本质是多行变量
- 预定义的call函数在调用时将参数传递给多行变量
- 自定义函数是call参数的实参,并在call中被执行 示例4--call调用多行变量(call无法调用变量)
.PHONY : testdefine func1 @echo "my name is $(0)"endeffunc2 := @echo "my name is $(0)"test : $(call func1) $(call func2)复制代码
示例5--call调用多行变量
.PHONY : testdefine func1 @echo "my name is $(0)"endefdefine func2 @echo "my name is $(0)"endeftest : $(call func1) $(call func2)复制代码
示例6--自定义函数与预定义函数区别
.PHONY : testdefine func1 @echo "my name is $(0)"endefdefine func2 @echo "my name is $(0)"endefvar1 := $(call func1)var2 := $(call func2)var3 := $(abspath ./)var4 := $(abspath test.app)test : @echo "var1 => $(var1)" @echo "var2 => $(var2)" @echo "var3 => $(var3)" @echo "var4 => $(var4)"复制代码
小结
- make解释器提供了一系列的函数供makefile调用
- 自定义函数是一个多行变量,无法直接调用,只能借助于call进行间接调用
- 自定义函数用于定义命令集合,并应用于规则中
- 预定义的call函数在调用时将参数传递给多行变量
- 自定义函数是call函数的实参,并在call中被执行