1、Makefile的命令行中前面的@表示静默执行。
2、Makefilezhon中默认情况下是先将这一行命令打印出来,然后在执行这条命令。
3、不打印命令,直接执行命令,在命令前加@
4、Makefile中几种变量赋值运算符
(1)=
最简单的赋值
(2):=
一般也是赋值
用=赋值的变量,在被解析是他在Makefile中取决于最后一次赋值时的值,用:=赋值是不随最后Makefile的值的变化,只看前面的值即可。
例:
VAR_A=abcd
VAR_B=$(VAR_A)
VAR_C:=$(VAR_A)
VAR_A=efgh
此时$(VAR_B)为efgh随VAR_A变化
$(VAR_C)为abcd不随VAR_A变化
(3)?=
如果变量前面没有赋值过则执行这条语句,如果前面已经赋值过了则本行被忽略。(实验可以看出:所谓的没有赋值过就是这个变量没有被定义过。才会执行这条命令)
(4)+=
用来给一个已经赋值的变量连续赋值,意思就是可以把Makefile中的变量看成一个字符串,+=后面的字符串接续到之前的字符串。
注意:Makefile中并不要求赋值运算符两边一定要有空格或者无空格,这个比shell的格式要求松一些。
5、Makefile的环境变量
(1)makefile中用export导出的就是环境变量。一般情况下要求环境变量名用大写,普通变量名用小写。
(2)环境变量和普通变量不同,可以理解为:环境变量是整个工程中所有的Makefile中可以共同使用的全局变量,而普通
变量只是当前本Makefile中使用的局部变量。所有要注意:定义了一个环境变量,会影响其他Makefile文件。
(3)Makefile中可能有一些环境变量是makefile本身自己定义的内部的环境变量。这就好像是C语言中编译器预定义的宏__LINE__ __FUNCTION__等一样。