函数定义及调用
1、makefile中支持函数的概念
- make解释器提供了一些列的函数供makefile调用
- 在makefile中支持自定义函数实现,并调用执行
- 通过define关键字实现自定义函数
2、自定义函数的语法
3、深入理解自定义函数
- 自定义函数是一个多行变量,无法直接调用
- 自定义函数是一种过程调用,没有任何的返回值
- 自定义函数用于定义命令集合,并应用于规则中
4、编程实验
.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
#必须在规则中调用,此处只是吧func1当做变量处理
var := $(call func1)
new := $(func1)
test :
@echo "var => $(var)"
@echo "new => $(new)"
$(call func1)
$(call func2, D2, D3)
#call的作用,将实参值替换到多行变量的对应位置
//编译运行
$ make
var => @echo My name is func1
new => @echo My name is
My name is func1
My name is func2
Param 1 => D2
Param 2 => D3
5、make解释器中的预定义函数
- make的函数提供了处理文件名,变量和命令的函数
- 可以在需要的地方调用函数来处理指定的参数
- 函数在调用的地方被替换为处理结果
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.cpp)
test :
@echo "var1 => $(var1)"
@echo "var2 => $(var2)"
@echo "var3 => $(var3)"
@echo "var4 => $(var4)"
//编译运行
$ make
var1 => @echo My name is func1
var2 => @echo My name is func2
var3 => /mnt/hgfs/VMShare/hello7688/ditai/make/9
var4 => /mnt/hgfs/VMShare/hello7688/ditai/make/9/test.cpp
7、小结
- make解释器提供了一系列的供makefile调用
- 自定义函数是一个多行变量,无法直接调用
- 自定义函数用于定义命令集合,并应用于规则中
- 预定义的call函数在调用时将参数传递给多行变量
- 自定义函数是call函数的实参,并在call中被调用