在Makefile中我们经常看到 = := ?= +=这几个赋值运算符,那么他们有什么区别呢?我们来做个简单的实验

新建一个Makefile,内容为:
ifdef DEFINE_VRE
    VRE = “Hello World!”
else
endif

ifeq ($(OPT),define)
    VRE ?= “Hello World! First!”
endif

ifeq ($(OPT),add)
    VRE += “Kelly!”
endif

ifeq ($(OPT),recover)
    VRE := “Hello World! Again!”
endif

all:
    @echo $(VRE)

敲入以下make命令:
make DEFINE_VRE=true OPT=define 输出:Hello World!
make DEFINE_VRE=true OPT=add 输出:Hello World! Kelly!
make DEFINE_VRE=true OPT=recover  输出:Hello World! Again!
make DEFINE_VRE= OPT=define 输出:Hello World! First!
make DEFINE_VRE= OPT=add 输出:Kelly!
make DEFINE_VRE= OPT=recover 输出:Hello World! Again!

从上面的结果中我们可以清楚的看到他们的区别了
= 是最基本的赋值
:= 是覆盖之前的值
?= 是如果没有被赋值过就赋予等号后面的值
+= 是添加等号后面的值

之前一直纠结makefile中“=”和“:=”的区别到底有什么区别,因为给变量赋值时,两个符号都在使用。网上搜了一下,有人给出了解答,但是本人愚钝,看不懂什么意思。几寻无果之下,也就放下了。今天看一篇博客,无意中发现作者对于这个问题做了很好的解答。解决问题之余不免感叹,有时候给个例子不就清楚了吗?为什么非要说得那么学术呢。^_^

1、“=”

make会将整个makefile展开后,再决定变量的值。也就是说,变量的值将会是整个makefile中最后被指定的值。看例子:

x = foo
            y = $(x) bar
            x = xyz

在上例中,y的值将会是 xyz bar ,而不是 foo bar 。

2、“:=”

“:=”表示变量的值决定于它在makefile中的位置,而不是整个makefile展开后的最终值。

x := foo
            y := $(x) bar
            x := xyz

在上例中,y的值将会是 foo bar ,而不是 xyz bar 了。

makefile 中 =, :=, ?=, +=的区别相关推荐

  1. Makefile 中:= ?= += =的区别

    from :http://www.cnblogs.com/wanqieddy/archive/2011/09/21/2184257.html Makefile 中:= ?= += =的区别 在Make ...

  2. makefile中 = ,:=,+=有怎么区别?

    = 是最基本的赋值 := 是覆盖之前的值 ?= 是如果没有被赋值过就赋予等号后面的值 += 是添加等号后面的值 1."=" make会将整个makefile展开后,再决定变量的值. ...

  3. 【Linux + Makefile】Makefile中的.PHONY作用以及赋值运算(各种=符号)的区别

    笔者常年在Linux环境编程,经常在项目中与Makefile打交道,最近总结了几个Makefile的小的知识点,分享给大家. 通过阅读本文,你将了解到以下知识: 1.Makefilke中的.PHONY ...

  4. Android Makefile中inherit-product函数简介,以及与include的区别

    在 Android Makefile 中时不时会看见 inherit-product 函数的使用,类似下方这样:         $(call  inherit-product,  vendor/do ...

  5. Makefile中指示符“include”、“-include”和“sinclude”的区别

    指示符"include"."-include"和"sinclude" 如果指示符"include"指定的文件不是以斜线开 ...

  6. Android Makefile中inherit-product函数和include的区别

    在 Android Makefile中inherit-product函数和include都是执行某个文件. include 使用: include device/mediatek/mt2712/dev ...

  7. makefile中变量有哪些?

    make一些参数选项: -p 选项,可以打印出make过程中的数据库, 下面研究一下内置的变量和规则. -n 选项, 只运行,不执行, -d 选项,相当于–debug=a,b(basic),v(ver ...

  8. Linux Makefile 中的陷阱【转】

    转自:https://blog.csdn.net/QQ1452008/article/details/52247944 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog. ...

  9. 简单聊一下makefile中的 =, :=, ?=和+=

    最容易混淆的是 =和:=, 我们先来看看makefile: [plain] view plaincopy x = hello y = $(x) x = world test1: test1.cpp @ ...

最新文章

  1. python字典练习题
  2. phpstorm运行java项目_phpstorm的提速设置
  3. GDCM:输出DataSet的测试程序
  4. html5哪个输入字段必填,HTML5:如何使用“required”属性和“radio”输入字段
  5. python基础之---03基本语法
  6. 日期年月日的比较以及判断
  7. 前端学习(575):margin无效情形之鞭长莫及导致无效
  8. 【u107】数字游戏(bds)
  9. 大小端判断及相互转化
  10. UE4之vs2019IntelliSense错误
  11. VS2017设置C++标准
  12. BZOJ4311:向量——题解
  13. 慎用"加速"一词,可以使用"早日"代替
  14. (c语言)将一个三位数逆序输出
  15. java p3c_阿里p3c(代码规范,eclipse插件、模版,idea插件)
  16. Google Code checkout v8 方法
  17. Linux系统之账号和权限管理
  18. 本周最新文献速递20211219
  19. 免费下载的音乐的6个网站,非常实用!
  20. malloc、calloc、realloc函数讲解

热门文章

  1. python怎么画函数图_可视化|Python绘制桑基图
  2. matlab中的mkdir函数_科学网—Matlab中计算函数运行时间的三种方法及判断新建文件夹 - 张伟的博文...
  3. 解压ubi文件_制作ubi文件系统
  4. 使用Python,OpenCV和Haar级联进行人脸检测——轻量级的人脸检测器
  5. 读后感与机翻《人类因果学习的分解:自下而上的联想学习和自上而下的图式推理》
  6. 小R SLAM机器人树莓派3b+ ROS kinetic 环境搭建笔记
  7. 洛谷P1110 报表统计 multiset stl好题
  8. 机器学习(18)-- SVM支持向量机(根据身高体重分类性别)
  9. Java内部类手机专卖店_Java(20)内部类
  10. 剑指offer:面试题32 - III. 从上到下打印二叉树 III