首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Makefile中:=, =, ?=和+=的含义

在Makefile语法中,时不时会见到各种“=”号的赋值语句,除了常见的“=”和“:=”,还有“?=”等 那么这些赋值等号分别表示什么含义呢?...“=” “=”是最普通的等号,然而在Makefile中确实最容易搞错的赋值等号,使用”=”进行赋值,变量的值是整个makefile中最后被指定的值。...在make时,会把整个makefile展开,拉通决定变量的值 “:=” 相比于前面“最普通”的”=”,”:=”就容易理解多了。”:=”就表示直接赋值,赋予当前位置的值。...因此相比于”=”,”:=”才是真正意义上的直接赋值。 “?=” “?=”表示如果该变量没有被赋值,则赋予等号后的值。举例: VIR ?...= new_value 这种情况下,VIR的值就是old_value “+=” “+=”和平时写代码的理解是一样的,表示将等号后面的值添加到前面的变量上

1.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Makefile中的Shell脚本简介

    给很多刚接触Makefile的人: 1、Makefile中可以嵌入shell脚本,而且能像shell脚本中一样,各种命令、控制结构都可使用。 2、Makefile的主要结构是 ......3、Makefile中的shell,不同的行在不同的进程中执行,不同的行直接不能传递变量,所以很多时候shell都尽量使用反斜杠()来把相关的内容串成一行。...4、Makefile变量和shell变量是两个不同的东西,并且为了避免Makefile变量和shell变量冲突,引用Makefile变量最好使用$(Makefile_Var),引用shell变量时最好使用...5、Makefile的多字符变量只能使用$(VAR)或${VAR}来引用,不能使用$VAR,$VAR会被解释成$(V)AR....但如果在纯粹的shell编程中,纯shell脚本里可以使用$VAR来引用VAR这个变量。 收藏于 2012-08-08

    2.1K80

    Linux CC++工程中可生成ELF、动静态库文件的通用Makefile

    更建议的做法是在当前C/C++工程的配置文件中设置LIBPATH参数为动态库所在的目录,这样就不用在设置变量LD_LIB_DIR的值了,例如: export LIBPATH=/usr/lib64/:${...LIBPATH}:/home/typecodes/lib 最后需要说明的是,变量$(PROJECT_DIR)表示当前C/C++工程的根路径,可以直接将本Makefile文件中的命令# PROJECT_DIR...同样,更建议在工程的配置文件中配置,例如: export PROJECT_DIR=/home/typecodes 2 使用方法 在配置好Makefile文件中的变量对应的值后,直接将该文件放置在需要编译的...伪目标clean对应的命令make clean能够清除上次执行make命令产生的影响;伪目标help对应的命令make help能够在界面上输出Makefile文件中的重要变量的值,方便调试。...3 附录:Makefile文件源码 已将下面的Makefile源文件托管到两个仓库中: 1、GitHub: https://github.com/vfhky/General_Makefile; 2、Coding

    43110

    Linux CC++工程中可生成 ELF、动静态库文件的通用 Makefile(二)

    今天对之前写的 Linux C/C++工程中可生成ELF、动/静态库文件的通用Makefile - TypeCodes 文章里面的 Makefile 进行了优化,增加了在当前目录生成单个可执行文件的功能...1 功能说明 之前已有的功能不再赘述,这次主要是在包含多个 cpp 文件的项目中生成一个可执行文件(之前只能一个 cpp 或者 c 文件生成对应的一个可执行文件)。...如上图所示,我的一个 myRedisSentinel 目录中包含了多个 cpp 文件,然后只要在 SINGLE_BIN 里面配置想要输出的可执行文件名称,最后执行 make -j4 命令即可生成。...2 附录:Makefile 文件源码 已将下面的 Makefile 源文件托管到 github仓库中: 1、GitHub: https://github.com/vfhky/General_Makefile...: A general makefile to generate an ELF or a # dynamic or a static library for

    11310

    Linux CC++工程中可生成 ELF、动静态库文件的通用 Makefile(二)

    今天对之前写的 Linux C/C++工程中可生成ELF、动/静态库文件的通用Makefile - TypeCodes 文章里面的 Makefile 进行了优化,增加了在当前目录生成单个可执行文件的功能...1 功能说明 之前已有的功能不再赘述,这次主要是在包含多个 cpp 文件的项目中生成一个可执行文件(之前只能一个 cpp 或者 c 文件生成对应的一个可执行文件)。...如上图所示,我的一个 myRedisSentinel 目录中包含了多个 cpp 文件,然后只要在 SINGLE_BIN 里面配置想要输出的可执行文件名称,最后执行 make -j4 命令即可生成。...2 附录:Makefile 文件源码 已将下面的 Makefile 源文件托管到 github仓库中: 1、GitHub: https://github.com/vfhky/General_Makefile...: A general makefile to generate an ELF or a # dynamic or a static library for

    12610

    如何在JavaScript中访问暂未存在的嵌套对象

    JavaScript 是个很神奇的东西。但是 JavaScript中的一些东西确实很奇怪,让人摸不着头脑。...其中之一就是当你试图访问嵌套对象时,会遇到这个错误 Cannot read property 'foo' of undefined 在大多数情况下,处理嵌套的对象,通常我们需要安全地访问最内层嵌套的值。...user.personalInfo.name : null; 如果你的嵌套结构很简单,这是可以的,但是如果数据嵌套五或六层深,那么你的代码就会看起很混乱: let city; if ( data...,如 Lodash 和 Ramda,可以做到这一点。...但是在轻量级前端项目中,特别是如果你只需要这些库中的一两个方法时,最好选择另一个轻量级库,或者编写自己的库。

    8.1K20

    Makefile文件中,两个$的变量变量$$Xxx 与一个$的变量 $Xxx的区别

    原文地址:Makefile文件中,两个\$的变量变量\$\$Xxx 与一个\$的变量 \$Xxx的区别Makefile 中的变量引用在 Makefile 中,$ 符号用于变量替换,但它的使用方式有一些细微的区别...:单个 $ 符号($Xxx)用途:用于引用 Makefile 中定义的变量。...双 $ 符号(\$\$Xxx)用途:用于在 Makefile 中传递给 shell 的命令中引用 shell 变量。用法:\$\$ 会被 make 解析为单个\$,从而在 shell 中使用。...具体区别$Xxx:用于 Makefile 变量替换。make 会在执行命令之前将其替换为变量的值。\$\$Xxx:用于传递给 shell 的命令中引用 shell 变量。...echo \$\$USER:make 会将 \$\$USER 转换为 $USER,然后 shell 会替换 $USER 为当前用户的用户名。总结使用 $ 来引用 Makefile 中的变量。

    6310

    makefile从入门到放弃——博主吐血整理的笔记

    文章目录 make简介 makefile基本结构 makefile的基本使用实例 makefile变量 make的使用 makefile的隐含规则 makefile的VPATH makefile的嵌套...其与C/C++所不同的是,你可以在Makefile中改变其值。在makefile中,变量可以使用在“目标”,“依赖目标”, “命令”或是Makefile的其它部分中。....o test 第二行代码中就是应用了规则二,目标文件可以改成f2、main都可以,但是必须是和所依赖的文件相关联,如果不关联(如:test)那么makefile就会报错。...这就是嵌套执行 make,我们把最外层的 Makefile 称为是总控 makefile。...上述的规则也可以换成另外一种写法: subsystem $(MAKE) -C subdir 在 make 的嵌套执行中,我们需要了解一个变量 “CURDIR”,此变量代表 make

    1.7K20

    Makefile总结

    Makefile是一个规定了怎么去编译和链接程序的脚本文件,在执行make命令时会执行该文件,window环境下的IDE,如visual studio已经集成了该功能,不需要关心程序的编译规则,在linux...目前centos 7.3 GNU的make版本是3.82 为什么要用Makefile 在做C/C++开发过程中,比如有如下文件: a.c b.c main.c 编译生成可执行二进制文件 gcc a.c...这种情况可以使用伪目标来解决,可避免在makefile中定义的执行命令目标和当前目录下实际文件名冲突。 一旦定义为伪目标,make执行规则不会去查找隐含规则,同样也提高了效率。...在上边的Makefile中把clean定义为伪目标即可 .PHONY:clean 还有个特表的伪目标 all ,如我们通过Makefile创建多个可执行文件时,可以使用到: 如: all: bin1 bin2...通过主目录下的Makefile分别管理各个目录下的Makefile编译。这就要用到嵌套执行。

    97410

    2023学习日志

    makefile 使用变量变量基础$makefile中的变量在声明时需要设置初始值,使用时需要在变量名前加" " ,可以通过使用括号()或大括号{}包围变量名示例:test = cpro.o: pro...$(test)变量展开不同于编程语言中变量的概念,Makefile中的变量更类似于c/c++中宏的概念,本质上是将变量的值替换到使用变量的地方变量的嵌套Makefile支持将变量的值赋给变量但为了防止变量的递归定义...,也可以在make命令行中指定变量的值,或在Makefile中定义该变量,覆盖系统环境变量的值。...当make嵌套调用时,上层定义的变量会以环境变量的形式传递到下层make中。...,next方法一次返回迭代器中的一项,封装在Some中,而迭代器结束时,将返回None消费适配器与迭代适配器消费适配器消费适配器即在Iterator trait 定义中调用了迭代器next方法的方法,如标准库实现的

    23500

    Linux内核的Makefile中cmd-check是如何检查前后两次执行的命令是一致的?

    Linux内核的构建工具用的是GNU Make,在其相关的Makefile中,有一个变量叫做cmd-check,其定义如下: # Check if both commands are the same...在if_changed命令中,如果$(newer-prereqs)$(cmd-check)部分展开后的结果不为空,则执行后面$(cmd)指向的命令,并将该命令用printf输出到特定的文件中。...cmd_link-vmlinux在Makefile中是有明确定义的,但cmd_vmlinux在Makefile中却没法找到明确定义的地方,这个也是初次研究linux内核的Makefile的同学会感到困惑的地方...这次的构建命令很容易获取,比如上面的cmd_link-vmlinux,是直接在Makefile中定义的,那上次的构建命令怎么获取呢? 对,肯定是保存到哪个文件里了。...这样,cmd-check中的$(cmd_$@)部分指向的内容我们也找到了。

    1.6K10
    领券