Makefile编译原理 函数的定义及调用

本文详细介绍了如何在Makefile中使用define定义并调用自定义函数,强调了自定义函数作为多行变量的特性,以及call函数在处理多行变量中的作用。还讨论了预定义函数的调用,展示了如何正确运用call来传递参数和获取函数结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.makefile中支持函数的概念

make解释器提供了一系列的函数供makefile调用

在makefile中支持自定义函数实现,并调用执行

通过define关键字实现自定义函数

实验:

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

深入理解自定义函数:

自定义函数是一个多行变量,无法直接调用

自定义函数是一种过程调用,没有任何的返回值

自定义函数用于定义命令集合,并应用于规则中

自定义函数调用深度理解:

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

实验:

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

二.预定义函数的调用

实验: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$ 

实验:调用 预定义函数

.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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

嵌入式_笔记

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

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

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

打赏作者

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

抵扣说明:

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

余额充值