makefile 变量的替换,嵌套引用,命令行变量

简介: makefile 变量的替换,嵌套引用,命令行变量

前言


一、变量替换:

1. 变量值的替换。

使用 指定的字符(串)替换变量值中的后缀字符(串)

语法格式: $(var:a=b) 或 ${var:a=b}

  • 替换表达式中不能有任何的空格。
  • make 中支持使用 ${ } 对变量进行取值。

示例 :

src1 := a.c b.c c.c
obj1 := $(src1:c=o)
test:
  @echo "obj1 => $(obj1)"

2. 变量的模式替换。

使用 % 保留变量值中的指定字符,替换其他字符。

语法格式: $(var:a%b=x%y) 或 ${var:a%b=x%y}

  • 替换表达式中不能有任何空格。
  • make 中支持 使用 $ { } 对变量进行取值。

示例 :

src1 := a1b.c  a2b.c  a3b.c
obj1 := $(src1:a%b=x%y) 
test1:
  @echo "obj1 => $(obj1)"
src2 := a11b.c  a22b.c  a33b.c
obj2 := $(src2:a%b=x%y) 
test2:
  @echo "obj2 => $(obj2)"

3. 规则中的模式替换。

表示,target-patterntarget 中匹配子目标;再通过 prereq-pattern 从子目标生成依赖; 进而构成完整的规则。

流程图

示例 :

CC := g++             # 变量的简单赋值
TARGET := hello-makefile.out
OBJS := func.o main.o const.o
$(TARGET) : $(OBJS)
  $(CC) -o $@ $^
$(OBJS) : %.o : %.c         # 采用规则中的模式替换
  $(CC) -o $@ -c $^
.PHONY : rebuild clean all      # 声明伪目标
rebuild : clean all
all : $(TARGET)
clean :
  $(RM) *.o $(TARGET)         # $(RM):用于删除文件的命令

  • 提问 : 为什莫使用 规则中的模式替换呢?

因为工程中我们的 .c .o 文件非常多。如果 想要将 .c 编译成 .o 文件时,

可以使用 这种替换方法。 直接将 文件 加在下面的 第一行后即可。

OBJS  := func.o main.o const.o

$(OBJS) : %.o : %.c

$(CC) -o $@ -c $^

这样可以很快的完成编译,减少工作量。

二、变量的嵌套使用

一个变量名之 可以包含对其他变量的引用

嵌套引用的本质是使用一个变量表示另一个变量。

x := y
y := z
a := $($(x))
test :
  @echo " a => $(a)"

需要注意的是,在变量值的嵌套引用中,Makefile 的解析顺序是从内而外的,即先解析内部的变量,再逐级向外解析外部的变量。

三、命令行变量

在 Makefile 中,可以使用命令行变量来传递参数给 Make 命令。

命令行变量可以在命令行中通过 “-变量名=变量值” 的方式定义,并在 Makefile 中使用 $(变量名) 的方式引用。

  • 运行 make 时,在命令行定义变量
  • 命令行变量默认 覆盖 makefile 中定义的变量。
hm := hello
test :
  @echo " hm => $(hm)"    # 在命令行改变其值
  @echo " new =>$(new)"   # 打印未定义的变量,在命令行定义赋值

四、override ,define 关键字

  1. override 关键字:
  • 用于指示 makefile 中定义的变量不能被覆盖
  • 变量的定义和赋值都需要使用 override 关键字。
override hm := hello
test :
  @echo " hm => $(hm)"    # 在命令行改变其值

  1. define 关键字:
  • 用于在 makefile 中定义多行变量
  • 多行变量的定义从变量名开始 到 endef结束
  • 可使用 override 关键字防止变量被覆盖。
  • define 定义的变量等价于使用 = 定义的变量。
define fool 
I'm fool!
endef
override define cmd       # 使用 override 防止变量被覆盖
  @echo "run cmd ls ..."
  @ls
endef
test :
  @echo "f00 => $(fool)"
  $(cmd)        # 调用 cmd 变量


总结

下一篇 介绍 makefile 的全局变量,文件变量,局部变量。

相关文章
|
Linux Go SoC
关于S3学习所涉及到的知识(二):Linux设备驱动suspend/resume的顺序
关于S3学习所涉及到的知识(二):Linux设备驱动suspend/resume的顺序
1090 0
|
安全 网络协议 网络安全
UDP Flood是什么?及其防护方法
UDP Flood是互联网上最经典的DDoS(Distributed Denial of Service)攻击之一。攻击者在短时间内向目标设备发送大量的UDP报文,导致链路拥塞甚至网络瘫痪。一般的UDP报文由攻击工具伪造,通常在数据段具备相同的特征,另一部分由真实网络设备发出的UDP报文,虽然数据段不相同,但固定的目的端口也可作为一种特征。 确定UDP攻击报文的特征后,即可根据特征进行过滤。特征过滤就是常说的指纹过滤,可根据攻击报文的特征,自定义过滤属性。指纹过滤包括静态指纹过滤和动态指纹学习两种方法。
UDP Flood是什么?及其防护方法
|
虚拟化 索引
看一下ARM的IP:SMMUU
看一下ARM的IP:SMMUU
1245 1
|
监控 网络协议 安全
|
存储 NoSQL Linux
linux之core文件如何查看和调试
通过设置和生成 core 文件,可以在程序崩溃时获取详细的调试信息。结合 GDB 等调试工具,可以深入分析 core 文件,找到程序崩溃的具体原因,并进行相应的修复。掌握这些调试技巧,对于提高程序的稳定性和可靠性具有重要意义。
7669 6
条件变量函数pthread_cond_timedwait实现业务场景
条件变量函数pthread_cond_timedwait实现业务场景
592 0
|
Rust Shell 索引
使用阿里云镜像加速Rust与Cargo安装及更新
使用阿里云镜像加速Rust与Cargo安装及更新
14011 2
|
前端开发 JavaScript
【node写接口】 通过node 快速搭建一个服务器、get请求、post请求 小白入门
【node写接口】 通过node 快速搭建一个服务器、get请求、post请求 小白入门
843 4
|
存储 Unix Shell
技术好文:TCL脚本语言基础介绍
技术好文:TCL脚本语言基础介绍
1495 1
|
Linux 编译器 测试技术
探索Linux中的objcopy命令:数据处理与分析的得力助手
`objcopy`是GNU工具集中的实用程序,用于复制和转换二进制目标文件,如ELF到S-record。它支持格式转换、内容提取和修改,如移除调试信息。命令参数包括指定输入/输出格式和复制特定段。示例用途有:`objcopy -O binary input.elf output.bin`(ELF转二进制)和`objcopy -j .text input.elf output.o`(复制.text段)。使用时注意文件格式、备份原始文件并查阅文档。对于处理和分析二进制数据,`objcopy`是不可或缺的工具。