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

来源:互联网 发布:软件自动化研究生 编辑:程序博客网 时间:2024/06/05 14:40

       最容易混淆的是 =和:=, 我们先来看看makefile:

x = helloy = $(x)x = worldtest1: test1.cpp@echo $(y)
       执行make后, 结果为world,  再看改动后的makefile:

x = helloy := $(x)x = worldtest1: test1.cpp@echo $(y)
       执行make后, 结果为hello,  为什么有区别呢?

       因为=其实类似于C++中的引用, 相当于y和x绑定了, 所以在echo的时候, 值为world

       而:=其实类似于C++中的赋值, 所以在echo的时候, 值为hello.   在makefile中, 强烈建议使用:=进行复制。


       y?=x是什么呢? 其实很好理解, 它的意思是: 如果y没有赋值过, 那就赋值。 如果赋值过, 那本次就不赋值了。

       y+=x是什么呢?  很好理解, 其实就是C++中的+=, 相当于累加。


       这些东西本来很简单, 但我发现, 有很多地方没讲清楚, 所以来唠叨一下。





1 0
原创粉丝点击