Makefile9--函数定义及调用

学习自狄泰软件学院唐佐临老师Makefile课程,文章中图片取自老师的PPT,仅用于个人笔记。


实验1 : 自定义函数调用实例
实验2 :自定义函数调用深度理解1
实验3 :自定义函数调用深度理解2
实验4 :call 处理的对象是多行变量
实验5:调用 预定义函数


在这里插入图片描述

在这里插入图片描述

/*
	$(0) : 代表 第0号参数 是 自定义函数名字
*/
define func1
	@echo "My name is $(0),"
endif


/*
	$(0) : 代表 第0号参数 是 自定义函数名字
	$(1) : 代表 第1号参数 是 当前函数在调用的时候第一个实参的值
*/
define func2
	@echo "My name is $(0),"
	@ehco "Param => $(1)"
endif

调用形式:

test :
	$(call func1) // 通过 call  调用自定义函数func1
	$(call func2,D.T.Software) //通过 call  调用自定义函数func2,后面是第一号实参。

在这里插入图片描述

实验1 : 自定义函数调用实例

.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$ 

实验2 :自定义函数调用深度理解1

.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 当做一个变量来处理了。自定义函数的本质就是多行变量。


实验3 :自定义函数调用深度理解2

.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,所以说并不会将这个变量里面的相应位置的地方换成实参。

结论

结论:在 makefile里面,其实是使用多行变量来模拟自定义函数,所谓定义的自定义函数 并不是定义了函数,而是定义了多行变量,只不过说我们使用call ,在 call 的作用下,可以将实参的值替换到多行变量的对应位置。call 的作用就是将实参替换到函数体当中对应的位置。通过前两个例子,可以知道,为什么自定义函数只能用于规则中才有函数意义并且只能用于定义命令的集合了,就是因为 命令只能在规则中被执行,在其他地方调用 多行变量 只是打印命令本身,有call 的话会替换一下实参。本身就是为了方便的在规则中调用一系列命令

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
自定义函数就是 call 这个预定义函数的实参,并且在call这个预定义函数内部被执行,其实就是参数的替换,替换之后得到的就是一系列 命令集合,既然是命令的集合,也就只能在规则中真正的执行了。

实验4 :call 处理的对象是多行变量

.PHONY : test

define func1
	@echo "My name is $(0)"
endef

# 不是多行变量
func2 := @echo "My name is $(0)"


test :

	$(call func1)
	$(call func2)#call 处理的是多行变量,这里的func2 并非是多行变量,不能正常工作 不传参

mhr@ubuntu:~/work/makefile1$ 
mhr@ubuntu:~/work/makefile1$ make
My name is func1
My name is 
mhr@ubuntu:~/work/makefile1$ 

实验5:调用 预定义函数

.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) # 当前目录下 cpp 文件的绝对路径

test :
	@echo "var1 => $(var1)"
	@echo "var2 => $(var2)"
	@echo "var3 => $(var3)"
	@echo "var4 => $(var4)"



mhr@ubuntu:~/work/makefile1$ 
mhr@ubuntu:~/work/makefile1$ make
var1 => 	@echo My name is func1
var2 => 	@echo My name is func2
var3 => /home/mhr/work/makefile1
var4 => /home/mhr/work/makefile1/test.cpp
mhr@ubuntu:~/work/makefile1$ 

解析:

/*
var1 := $(call func1)
var2 := $(call func2)
本质是调用了 call 函数,call 函数的内部用来处理 func1 func2这两个多行变量具体的
	值,就是将call 的参数替换到多行变量相对应的位置
*/
var1 => 	@echo My name is func1
var2 => 	@echo My name is func2

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Makefile中可以使用函数来处理变量,从而使命令或规则更加灵活和智能。Makefile支持的函数不多,但已经足够满足我们的需求。函数调用语法是使用$(function_name)的形式。其中,函数的返回值可以作为变量来使用。举个例子,error函数是一个可以在Makefile中使用的函数,它的作用是产生致命错误并向用户提示相应的信息,然后退出make的执行。需要注意的是,error函数只有在函数展开式(即函数调用时)才会提示错误并结束make进程。因此,如果函数出现在命令中或递归变量定义中,在读取Makefile时不会出现错误。只有在执行包含error函数的命令或展开引用该函数的递归变量时,才会提示致命信息并退出make的执行。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Makefile中常用到的函数总结](https://blog.csdn.net/qq_36823004/article/details/125223610)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [makefile中常用函数](https://blog.csdn.net/yangxuan0261/article/details/52060582)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Makefile中的常用函数介绍](https://blog.csdn.net/kyokowl/article/details/7357160)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Linux老A

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值