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

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

二.预定义函数的调用

Makefile编译原理 函数的定义及调用_第1张图片

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

你可能感兴趣的:(Linux驱动,linux,运维,服务器)