lora_gateway-master\util_tx_continuous---Makefile分析笔记

(1)

= 是最基本的赋值
:= 是覆盖之前的值
?= 是如果没有被赋值过就赋予等号后面的值
+= 是添加等号后面的值


之前一直纠结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 了。



(2)

Makefile中all的解释

all是个伪目标,是所有目标的目标,其功能是编译所有的目标。

例如,要把一个hello.cpp文件编译成hello

code:

------------------------------------------------------

all : hello another
 
hello : hello.cpp
     g++ -o $@ $<
 
another : another.cpp
     g++ -o $@ $<
-------------------------------------------------------

直接 make 或 make all 的话会执行 hello.cpp 和 another.cpp 的编译命令

后面不加参数的话,会把第一个目标作为默认的

make hello 的话只编译 hello.cpp

make another 的话只编译 another.cpp


$@ 表示目标

$< 表示第一个依赖

$^ 表示所有的依赖


$@ 表示目标 ---------hello
$ < 表示第一个依赖-------hello.cpp

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值