makefile--函数定义与调用

2,866 阅读2分钟

函数定义与调用


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中被执行