函数定义与调用
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)"
endef
var1 := $(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 : test
define func1
@echo "my name is $(0)"
endef
func2 := @echo "my name is $(0)"
test :
$(call func1)
$(call func2)
示例5--call调用多行变量
.PHONY : test
define func1
@echo "my name is $(0)"
endef
define func2
@echo "my name is $(0)"
endef
test :
$(call func1)
$(call func2)
示例6--自定义函数与预定义函数区别
.PHONY : test
define func1
@echo "my name is $(0)"
endef
define func2
@echo "my name is $(0)"
endef
var1 := $(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中被执行