博客
关于我
6. 变量的高级主题(上)
阅读量:377 次
发布时间:2019-03-05

本文共 1556 字,大约阅读时间需要 5 分钟。

1. 变量值的替换

在Makefile中,变量值的替换可以通过特定的语法来实现,以便更灵活地管理项目配置。以下是变量替换的主要方法:

1.1 使用指定字符替换变量值中的后缀字符

这种方法允许我们在变量值中找到特定的后缀字符,并将其替换为指定的新值。语法格式为$(var:a=b)或$(var:a=b)。需要注意的是,Makefile中的表达式中不能包含任何空格。例如:

src := a.cc b.cc c.cc

obj := $(src:cc=o)

在上述例子中,$(src:cc=o)会匹配src中的所有变量名,并替换其“.cc”后缀为“.o”,从而得到“a.o b.o c.o”。这种替换方式在处理文件扩展名或路径时非常有用。

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

这种方法允许我们保留变量值中的特定字符,同时替换其他字符。语法格式为$(var:a%b=x%y)或${var:a%b=x%y}。例如:

src := a1b.c a2b.c a3b.c

obj := $(src:a%b.c=x%y)

在上述例子中,$(src:a%b.c=x%y)会匹配src中的所有变量名,并将其“a%b.c”模式替换为“x%y”,从而得到“x1y.c x2y.c x3y.c”。这种方法适用于处理带有特定模式的文件名或路径。

2. 变量的模式替换

Makefile中的模式替换功能可以帮助我们在变量值中找到特定的模式,并将其替换为指定的新值。这对于处理文件扩展名或路径中的通用部分非常有用。

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

这种方法允许我们保留变量值中的特定字符,同时替换其他字符。语法格式为$(var:a%b=x%y)或${var:a%b=x%y}。例如:

src := a1b.c a2b.c a3b.c

obj := $(src:a%b.c=x%y)

在上述例子中,$(src:a%b.c=x%y)会匹配src中的所有变量名,并将其“a%b.c”模式替换为“x%y”,从而得到“x1y.c x2y.c x3y.c”。这种方法适用于处理带有特定模式的文件名或路径。

3. 规则中的模式替换

在Makefile中,模式替换不仅可以用于变量值的替换,还可以应用于目标文件的生成规则。这种方法可以简化规则的定义,特别是在处理大型项目时非常有用。

例如:

OBJS := func.o main.o

$(OBJS) : %.o : %.c
(tab)gcc -o $@ -c $^

上述Makefile中的规则可以等同于以下单独规则:

func.o : func.c

(tab)gcc -o $@ -c $^
main.o : main.c
(tab)gcc -o $@ -c $^

这种方法的好处在于,大型项目的规则可以显得更加简洁且易于维护。

4. 命令行变量

Makefile中的变量可以通过命令行参数进行设置,从而提供更高的灵活性。这种方法非常有用,尤其是在需要动态配置的情况下。

5. override关键字

在Makefile中,override关键字用于指示变量定义和赋值时不能覆盖现有的变量值。这对于防止意外覆盖已定义的变量非常有用。

例如:

.override = true

OBJ := $(OBJ)

在上述例子中,override关键字确保变量OBJ的值不会被重新定义或覆盖。

6. 小结

Makefile中的变量替换和模式替换功能为项目的配置提供了极大的灵活性。通过合理使用这些功能,可以显著简化Makefile的定义,提高项目的可维护性和可扩展性。同时,命令行变量和override关键字的支持进一步增强了Makefile的功能,使其能够更好地适应不同的开发需求。

转载地址:http://wzqg.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>
Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
查看>>
Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
查看>>
Mysql学习总结(8)——MySql基本查询、连接查询、子查询、正则表达查询讲解
查看>>
Mysql学习总结(9)——MySql视图原理讲解与使用大全
查看>>
MySQL学习笔记十七:复制特性
查看>>
Mysql学习第一课-mysql的定义及sql语句
查看>>
mysql安全模式: sql_safe_updates
查看>>