Makefile学习1

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__等一样。

猜你喜欢

转载自blog.csdn.net/weixin_40405692/article/details/83990944