Makefile学习之路——4

变量的类别有递归扩展变量和简单扩展变量。只用一个“=”符号定义的变量被称为递归扩展变量。通过下面例子观察递归扩展变量的特点。

1 .PHONY: all
2
3 foo=$(bar)
4 bar=$(ugh)
5 ugh=Huh?
6
7 all:
8     @echo $(foo)

从结果来看,递归扩展变量的引用是递归的。

CFLAGS =$(CFLAGS) -O

上面的赋值代码将会造成一个死循环,无限递归。

简单变量扩展使用“ :=”操作符来定义的。对于这种变量,make只对其进行一次操作,通过下面的代码来帮助我们理解:

 1 .PHONY: all
 2
 3 x=foo;
 4 y=$(x) b
 5 x=later
 6
 7 xx:=foo
 8 yy:=$(xx) b
 9 xx:=later
10
11 all:
12     @echo "X=$(y), xx=$(yy)"

递归和简单扩展变量相比的差距应该看出来了吧。递归相当于c++中的引用,而简单扩展变量make只对其进行一次展开。

下面对于同一个变量采取不同的赋值操作,看看会有什么效果。

1 .PHONY: all
2
3 objs=main.o foo.o bar.o utils.o
4 objs:=$(objs) another.o
5
6 all:
7     @echo $(objs)

如果把第二个简单扩展变量变成递归的即

objs=$(objs) another.o

make会报错

makefile:4:***递归变量‘objs‘引用本身(最终)。看来想引用自身的递归变量,编译器不会允许这样的行为。

时间: 2024-10-19 03:12:20

Makefile学习之路——4的相关文章

Makefile学习之路5——通过函数增强功能

通过函数能显著增强Makefile的功能.对于simple项目的Makefile,尽管使用了模式规则,但还是有一件比较麻烦的事情,就是要在Makefile中指明每一个项目源文件.下面介绍几个后期会使用到的函数,更多请参考<GUN Make>. 1.abspath函数 从命名就应该能够猜出它的作用.abspath函数用于将_name中的各路径名转化成绝对路径,并将转化后的结果返回.调用形式为: $(abspath _name) 1 .PHONY: all 2 root :=$(abspath /

makefile学习之路——makefile简介

一.make简介 make是一个指令工具,它解释makefile中的指令或者说规则.makefile文件描述了整个工程中所有文件的**编译顺序,编译规则**.Makefile也有自己的编写规则,通常,我们所使用的IDE都会生成相应的makefile,然后再根据makefile来进行编译,只是这些操作是由IDE来完成,我们只需要点击一个编译按钮. 二.为什么要使用make 现在可以在GitHub上看到,很多的开源项目,在编译的时候,都是使用make来完成的,也就是说,都有其对应的makefile.

makefile学习之路——变量

在makefile中,支持程序设计语言中变量的概念,所有的变量只代表文本数据. 一.变量的定义和使用 #变量的定义 CC := gcc TARGET := hello.out #变量的使用 $(TARGET) : func.o main.o     $(CC) -o $(TARGET) func.o main.o 二.变量的赋值方式 1. 简单赋值        := 只针对当前语句的变量有效 2. 递归赋值        = 赋值操作可能影响多个其他变量,所有与目标变量相关的其他变量都将受到影

QT基础学习之路

以下内容是自己想要学习的东西,从FinderCheng前辈的BLOG中学习到的,如有冒犯请告知,我会第一时间修正. 最近在看FinderCheng前辈的QT学习之路 从中总结出了自己想要学习的东西 留个信号,自己以后再来看的时候知道自己从哪里看过,并且可以更好的记住. 1.QT的SIGNAL/SLOT机制使得程序看起来很明白,类似于windows下面的消息机制 不过也带来一点小麻烦 必须要使用QT的qmake对程序进行预处理,才能够使用make或者nmake进行编译.并且它的界面也不是原生风格的

Azure云平台学习之路(三)——Cloud Services

1.什么是云服务? 能够部署高度可用的且可无限缩放的应用程序和API.简而言之,就是你写的CMD程序按照一定的框架进行少量修改就能运行在Azure云平台上. 2.Azure云服务有什么特点? (1)专注应用程序而不是硬件,PaaS的一种. (2)支持多种框架和语言. (3)集成了运行状况监视和负载平衡. (4)自动缩放优化成本和性能 3.建立云服务之前,我们需要建立一个云存储,来记录我们的程序的日志信息(当然,这不是必须的) (1)选择左边导航栏的"存储".主面板上显示的是所有已有的存

linux学习之路之LVM

试想一种情况,当初我们在规划磁盘的时候,只给某一个磁盘或分区之划分了30G的容量,但是后来,随着业务的需求,该磁盘或者分区的使用量会越来越大,等到以后再有数据存放时,发现该磁盘或者分区的容量不够用,此时该怎么办了?可以新增一个磁盘,经过格式化,挂载等过程就可以使用这个磁盘了,再将原来磁盘的数据完全的复制过来.等到后来又发现,规划的磁盘又太大了,然后又使用上述方法来减少磁盘的大小.虽然这种方法可行,但是效率低,比较复杂.不应该是我们首选的方法. 当然,我们可以这样做,将多个磁盘或者分区(PV)组合

我的算法学习之路

关于 严格来说,本文题目应该是我的数据结构和算法学习之路,但这个写法实在太绕口--况且CS中的算法往往暗指数据结构和算法(例如算法导论指的实际上是数据结构和算法导论),所以我认为本文题目是合理的. 这篇文章讲了什么? 我这些年学习数据结构和算法的总结. 一些不错的算法书籍和教程. 算法的重要性. 初学 第一次接触数据结构是在大二下学期的数据结构课程.然而这门课程并没有让我入门--当时自己正忙于倒卖各种MP3和耳机,对于这些课程根本就不屑一顾--反正最后考试划个重点也能过,于是这门整个计算机专业本

一个女大学生的代码学习之路(二)

首先说一下,写这种文章是由于我在四月四日晚上,在手动搭建自己的第一个ssh项目的时候,遇到了一个配置的问题,怎么解决也弄不好,当时是四号晚上九点,我看了一眼表,我就想两个小时之内,我要是能搞定就算行了,但是其实,我搞到三点才OK(凌晨),那时候已经是五号了,转天是一家子去扫墓的时候,结果我居然以这种一个理由没有去,理由是我太累了么?我只是就是搭了一个架子,就是由于我的包太混乱了,导致不兼容,所以tomcat总也不启动,你可能认为好笑,这么简单一个问题怎么就费这多多时间呢,但是作为一个刚接触三框架

kafka学习之路(二)——提高

kafka学习之路(二)--提高 消息发送流程 因为Kafka内在就是分布式的,一个Kafka集群通常包括多个代理.为了均衡负载,将话题分成多个分区,每个代理存储一或多个分区.多个生产者和消费者能够同时生产和获取消息.     过程: 1.Producer根据指定的partition方法(round-robin.hash等),将消息发布到指定topic的partition里面 2.kafka集群接收到Producer发过来的消息后,将其持久化到硬盘,并保留消息指定时长(可配置),而不关注消息是否