您的位置:首页 > 其它

makefile中=、:=和+=的区别

2015-06-19 17:00 253 查看
疯雨-版权所有,转载请注明【http://blog.csdn.net/u010346967】

经常有人分不清= 、:=和+=的区别 这里我总结下做下详细的分析:

首先你得清楚makefile的运行环境,因为我是linux系统,那么我得运行环境是shell

在Linux的shell里,shell只认识字符串,所以你就不要说整形什么的了。说值也不贴切。

先看+=是什么意思?

因为shell只认识字符串,所以这里应该不难联想到+=就是字符串连接的意思。相当于c语言的 strcat

举个例子:

x本来是 U;

x += SB;

那么运行结果就是 x为USB;

接着理解:=和=

这个是很常用的,比=用得多

看下面的例子:

x = sb;

y = u$(x)

x = all

运行结果x 是all y是uall

将=改成:=

x := sb;

y := u$(x)

x := all

运行结果x是all y是usb
怎么样?有感觉了吧。这里=的话算$(x)的时候会一直搜索到文件最后,最后再赋值。

而:=则不会搜索后面的x值。也就是前面的是有效的而引用变量之后的就是无效的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: