【Makefile由浅入深完全学习记录6】Makefile中变量的高级主题上

抓住基础,学习更多技术,迎接挑战,加qq:1126137994 微信:liu1126137994 一起学习更多技术~

上一篇文章学习了makefile中的预定义变量的使用,今天来继续学习makefile中的变量!

1、变量值的替换

变量值的替换:
*使用指定字符(串),替换变量值中的后缀字符(串)
-语法格式:$(var:a=b)${var:a=b}.
注意事项:

  • 替换表达式中不能有任何的空格
  • make中支持使用${}对变量进行取值
    举个例子:
src := a.o b.o c.o
obj := $(src:cc=o)test:@echo "obj => $(obj)"

变量的模式替换:

*使用%保留变量值中的指定字符,替换其他字符
-语法格式:$(var:a%b=x%y) 或者 ${var:a%b=x%y}

注意事项:

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

举个例子深刻理解一下:

src: a1b.c a2b.c a3b.c
obj: $(src:a%b.c=x%y)test:@echo "obj => $(obj)"

下面给出一个简单的示例来理解上面的语法:

src1 := a.cc b.cc c.cc
obj1 := $(src1:cc=o)test :@echo "obj1 => $(obj1)"src2 := a11b.c a22b.c a33b.c
obj2 := $(src2:a%b.c=x%y)test2 :@echo "obj2 => $(obj2)"

输入:make test
显示:obj1 => a.o b.o c.o
输入:make test2
显示:obj2 => x11y x22y x33y

规则中的模式替换:

这里写图片描述
意义:
通过target-pattern 从tagets中匹配子目标;再通过prereq-pattern从子目标生成依赖;进而构成完整的规则!!!

下面是一个规则中的模式替换案例:

OBJS := func.o main.o
$(OBJS) : %.o : %.cgcc -o $@ -c $^

等价于下面的:

func.o : func.cgcc -o $@ -c $^
main.o : main.cgcc -o $@ -c $^

下面看一个规则中的模式替换的案例:
main.c程序:


extern void foo();int main()
{foo();return 0;
}   

func.c程序

#include "stdio.h"extern char* g_hello;void foo()
{printf("void foo() : %s\n", g_hello);
}

const.c程序:

const char* g_hello = "hello makefile";

上述三个程序为源程序,编译他们的makefile文件为:


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 allrebuild : clean allall : $(TARGET)clean :$(RM) *.o $(TARGET)

输入make进行编译:
显示:g++ -o hello-makefile.out func.o main.o const.o

执行生成的可执行文件:
./hello-makefile.out
显示:
void foo() : hello makefile

2、变量值的嵌套引用

变量值的嵌套引用:
*一个变量名之中,可以包含对其他变量的引用
*嵌套引用的本质是用一个变量表示另外一个变量
这里写图片描述

命令行变量:
*运行make时,在命令行定义变量
*命令行变量默认覆盖makefile中定义的变量
这里写图片描述

override关键字:
*用于指示makefile中定义的变量不能被覆盖
*变量的定义和赋值都需要用override关键字
这里写图片描述

define关键字:
*用于在makefile中定义多行变量
*多行变量的定义从变量名开始,到endef结束
*可使用override关键字防止定义的变量被覆盖
*define定义的变量等价于使用 “=” 定义的变量(递归赋值)
这里写图片描述

下面给出一个例子来理解上述的语法理论:


hm := hello makefileoverride var := override-testdefine foo
I'm fool!
endefoverride define cmd@echo "run cmd ls ..."@ls
endeftest :@echo "hm => $(hm)"@echo "var => $(var)"@echo "foo => $(foo)"${cmd}

输入make,显示:
这里写图片描述

3、总结

  • 变量值的替换($(var:a=b) 或者 ${var:a=b}
  • 变量的模式替换($(var:a%b=x%y) 或者 ${var:a%b=x%y}
  • makefile支持将模式替换直接用在规则中
  • makefile中的变量值可以嵌套使用
  • 命令行中定义的变量可以覆盖makefile中的变量
  • override用于指示makefile中的变量不能被覆盖
  • define用于makefile中定义值为多行的变量

想一起探讨以及获得各种学习资源加我:
qq:1126137994
微信:liu1126137994
可以共同交流关于嵌入式,操作系统,C++语言,C语言,数据结构等技术问题。

本学习记录完全来源于狄泰软件学院的相关课程,可以加我q:1126137994或者Q群:199546072 ,给你推荐更多学习课程。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/423212.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

USB转WIFI无线网卡驱动程序(内核自带RT5370驱动程序添加)的移植记录之二

学习交流加 个人qq: 1126137994个人微信: liu1126137994学习交流资源分享qq群: 962535112 今天记录我在I.MX6Q平台添加内核自带RT5370无线网卡驱动程序的过程,加qq1126137994 微信:liu1126137994 共同学习更多技术&…

Node.js安装详细步骤教程(Windows版)

Node.js安装详细步骤教程(Windows版) 什么是Node.js? 简单的说 Node.js 就是运行在服务端的 JavaScript。 Node.js是一个基于 Chrome V8 引擎的 JavaScript 运行环境; Node.js使用一个事件驱动、非阻塞式 I/O 的模型,使其轻量且高效&…

移植wpa_supplicant软件与DHCP软件解密WPA/WPA2 加密的无线网络

加qq1126137994与微信:liu1126137994 一起学习更多技术! 现在的无线网络基本都是 WPA/WPA2 加密方式的,当我们在嵌入式Linux平台要实现无线网卡连接无线网时,我们需要一些工具来解密WPA/WPA2 加密方式的无线网。wpa_supplicant软…

xshell 连接不了 centos7

xshell 连接不了 centos7 采用的是net模式 有一段时间没有使用虚拟机了:今天打开后突然不能使用了,发现主机ping不通虚拟机了,而虚拟机可以正常联网,可以ping主机 查了一下 vmnet8 自动分配的 ipv4 和虚拟机 分配的网关地址没…

java多线程思维导图

分享是最好的整理,利用csdn 平台保存一下

【Makefile由浅入深完全学习记录7】Makefile中变量的高级主题下

加qq:1126137994 微信:liu1126137994 一起学习更多技术~ 继续上一篇文章关于变量的学习! 1、环境变量(全局变量) -makefile中能够直接使用环境变量的值 如果makefile中定义了同名变量,则环境变量将被覆…

【Makefile由浅入深完全学习记录8】条件判断语句

加qq:1126137994 微信:liu1126137994 一起学习更多技术~ 今天来学习Makefile中条件判断语句! Makefile也算是一门语言,它有自己的语法,那么它应该也会像C/C语言一样,支持条件判断语句! Makef…

C语言实现位数组(bit数组)与位数组的简单应用举例

学习交流加(可免费帮忙下载CSDN资源):个人微信: liu1126137994学习交流资源分享qq群1(已满): 962535112学习交流资源分享qq群2: 780902027 今天有朋友遇到一个笔试题:一个…

【常见笔试面试算法题12】动态规划算法案例分析

学习交流加 个人qq: 1126137994个人微信: liu1126137994学习交流资源分享qq群: 962535112 文章目录1、暴力搜索方法2、记忆搜索方法3、动态规划方法4、各种动态规划方法案例总结:给定数组arr,arr中所有数都为正数&…

kafka 思维导图

最近在培训沟通力过程中,一句话说的特别好,有输入就要有输出,最近又学习了一遍kafka 给大家分享一下

【C++深度剖析教程28】C++对象模型分析

学习交流加 个人qq: 1126137994个人微信: liu1126137994学习交流资源分享qq群: 962535112 今天记录学习的内容是:C对象模型分析!!! 本质分析: class是一种特殊的struct 在内存中cl…

【C++深度剖析教程29】C++对象模型分析下

加qq1126137994,微信:liu1126137994 一起学习更多技术!!! 今天来继续学习C对象模型! 在C编译器内部,类可以理解为结构体子类是由父类成员叠加子类新成员得到的 下面来写一个程序分析C的继承…

java 思维导图

最近有时间,又整理了一下java 思维导图,持续优化中 子模块拆分总结:java基础 java思维导图 总结

【常见笔试面试算法题12续集一】动态规划算法案例1台阶问题练习题

加qq1126137994 一起学习更多技术!!! 以下问题,都可以用非动态规划的方法做,我为了整理动态规划的方法思路,就全部用动态规划的思路来解决问题,这样还可以简化问题的处理,是时间复杂…

linux 思维导图

工作中使用总结的linux 分享一下

【常见笔试面试算法题12续集二】动态规划算法案例2矩阵最小路径和练习题

加qq1126137994 一起学习更多技术!!! 有一个矩阵map,它每个格子有一个权值。从左上角的格子开始每次只能向右或者向下走,最后到达右下角的位置,路径上所有的数字累加起来就是路径和,返回所有的…

mysql数据库思维导图

先前总结的一下数据库的思维导图,和大家分享一下,持续更新; 最近面试数据仓库工程师,过程中,问到索引类型,只是记得,普通索引,唯一索引,还有主键,面试中让说…

【常见笔试面试算法题12续集三】动态规划算法案例分析3 LIS练习题(最长上升子序列)

学习交流加 个人qq: 1126137994个人微信: liu1126137994学习交流资源分享qq群: 962535112 这是一个经典的LIS(即最长上升子序列)问题,请设计一个尽量优的解法求出序列的最长上升子序列的长度。 给定一个序列arr及它的长度n(长度小…

【常见笔试面试算法题12续集四】动态规划算法案例分析4 LCS练习题练习题(最长公共子序列的长度)

学习交流加 个人qq: 1126137994个人微信: liu1126137994学习交流资源分享qq群: 962535112 给定两个字符串A和B,返回两个字符串的最长公共子序列的长度。例如,A"1A2C3D4B56”,B"B1D23CA45B6A”&am…

hive 思维导图

1.整理了word文档,但是感觉没有思维导图清晰 ,持续更新中 ​ hive 工作中分享。