makefile--函数定义 函数调用

本文深入解析Makefile中的函数概念,包括自定义函数的定义与调用,以及预定义函数的应用。探讨了自定义函数作为多行变量的特性,以及如何通过call函数进行调用。同时,介绍了预定义函数在处理文件名、变量和命令时的作用。

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

函数定义与调用

转载自:https://www.jianshu.com/p/e2c78c8fb4a5

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中被执行
aml是一种xml格式的语言。 翻译过来大概叫 安全断言(标记)语言。 这里有两个点: 第一是“安全”, 第二是“断言(assertion)”。 用人话翻译saml就是 用安全的方式表达断言一种语言。 先看它的核心概念“断言”。 断言是什么? 就是做出判断的语言。比如一句话: 小明是超级管理员。 这就是一个断言。再来一个例子:小红没有权限读取根目录。这也是一个断言。 这种“做出判断的语句”我们在很多场合都需要用到。 比如你在网上尝试登陆一个服务的时候, 这个服务需要知道你是不是合法的用户。 这个时候如果你能提供一个“安全,可靠,可信任”的断言:“小明有权登陆XX服务”, 那么这个服务就知道你合法了, 于是就能为你提供服务了。 这个例子比较抽象,但基本上能表达断言在实际用例中的作用了。 实际上saml的大部分用例就在于证明你是谁,你拥有什么权限等等了。 saml中大部分主要内容也都是类似于:你是谁, 你有什么。。等等这些简单的语句。 详细内容后面会介绍。 接下来第二个概念就是“安全”了。 你能提供一个断言, 别人能不能假冒你提供一个断言从而骗取服务端的信任呢? 另外服务端为什么会信任你给的断言呢? 这就涉及到安全的问题了。为了防止断言被假冒,篡改。saml中加入了安全措施。 当然现今能抵御假冒,篡改,重放攻击的利器就是公钥-私钥系统了。 通过给断言加上签名和加密,再结合数字证书系统就确保了saml不受攻击。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值