Makefile 从变量中去掉一个item

来源:https://stackoverflow.com/questions/7402205/remove-item-from-a-makefile-variable

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Makefile ,您可以使用变量定义多个文件列表,并通过在规则引用变量的方式分别选择一个文件。 例如,如果您有以下变量: ``` FILES1 = file1.txt file2.txt file3.txt FILES2 = file4.txt file5.txt file6.txt ``` 您可以在规则使用以下语法选择第一个文件: ``` target: $(firstword $(FILES1)) # commands to build target ``` 同样的,您也可以使用以下语法选择第一个 FILES2 的文件: ``` target: $(firstword $(FILES2)) # commands to build target ``` ### 回答2: 在 Makefile ,我们可以使用多个变量来存储文件名,然后从这些变量分别取出一个文件。 假设我们有三个变量:`VAR1`、`VAR2`、`VAR3`,每个变量存储了一个文件名。我们可以使用以下方法从这些变量取出一个文件: ```makefile # 定义三个变量,存储文件名 VAR1 := file1.txt VAR2 := file2.txt VAR3 := file3.txt # 定义一个目标 target: # 取出 VAR1 变量的文件,并执行相关操作 $(shell echo "$(VAR1)") # 取出 VAR2 变量的文件,并执行相关操作 $(shell echo "$(VAR2)") # 取出 VAR3 变量的文件,并执行相关操作 $(shell echo "$(VAR3)") ``` 在上述示例,我们定义了三个变量 VAR1、VAR2 和 VAR3,分别存储了三个文件名。然后,在目标 `target` ,使用 `$(shell echo "$(VAR1)")` 的方式,从 VAR1 变量取出文件并执行相关操作。同样的方式,我们可以从 VAR2 和 VAR3 分别取出文件并进行操作。 通过这种方式,我们可以根据需要,从多个变量分别取出一个文件,并对其执行相应的操作。 ### 回答3: 在Makefile,我们可以使用多个变量来存储不同的文件路径,然后从这些变量分别取出一个文件。下面是一个简单的示例: 假设我们有三个变量:VAR1、VAR2和VAR3,分别存储了文件路径1、文件路径2和文件路径3。现在我们需要从这三个变量分别取出一个文件,并执行相应的操作。 首先,我们需要定义一个目标规则来执行操作。假设我们的目标规则是target,我们可以在目标规则使用$符号来引用变量的值。 ``` target: @echo "Executing operation on file from VAR1" @do_something $(VAR1) @echo "---------------------" @echo "Executing operation on file from VAR2" @do_something $(VAR2) @echo "---------------------" @echo "Executing operation on file from VAR3" @do_something $(VAR3) ``` 在上面的示例,我们首先输出一个提示信息,说明我们正在处理VAR1的文件。然后我们调用一个名为do_something的操作来处理VAR1的文件。接着我们重复这个过程,在每个VAR变量执行相应的操作。 需要注意的是,do_something是一个示例操作,你需要根据你的实际需求来替换它。你可以自定义操作或者使用Makefile已有的操作命令。 总结起来,当我们需要从多个变量分别取出一个文件时,在Makefile我们可以定义一个目标规则,并在该规则使用变量来引用相应的文件路径。这样就可以从多个变量取出文件,并执行相关操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值