博客
关于我
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 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>