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

 

Makefile 是一个用于自动化编译和构建程序的工具。它可以帮助开发人员管理项目中的依赖关系和文件的编译顺序,从而提高项目的编译效率和可维护性。 学习 Makefile 可以带来以下好处: 1. 自动化编译:通过 Makefile,我们可以定义编译规则和依赖关系,使得程序的编译过程更加自动化。只需要运行 make 命令,Makefile 将会根据文件的修改时间判断哪些文件需要重新编译,从而加快程序的构建速度。 2. 管理依赖关系:Makefile 支持定义不同文件之间的依赖关系,当某个文件被修改时,只有它的依赖文件也被修改了,才需要重新编译。这种管理依赖关系的方式可以减少不必要的编译时间,提高编译效率。 3. 支持多平台:Makefile 是跨平台的,可以在不同操作系统上使用。这意味着我们可以使用相同的 Makefile 来在 Windows、Linux、macOS 等多个平台上进行程序构建,而不需要为每个平台编写不同的构建脚本。 4. 高度可定制:Makefile 的语法相对简单,但非常灵活,允许开发人员根据项目的需求自定义规则。我们可以通过定义变量、宏、规则和命令等来构建一个适合自己项目的 Makefile,满足特定的编译和构建需求。 5. 方便协作开发:在多人协作开发项目时,使用 Makefile 可以统一编译和构建的方式,避免因为不同开发环境导致的构建问题。每个开发人员只需要按照 Makefile 中定义的规则进行编译,从而保证整个项目的一致性和可靠性。 总的来说,学习 Makefile 可以帮助我们更好地管理项目的编译和构建,提高开发效率和项目的可维护性。掌握 Makefile 的基本语法和原理,能够更好地适应大型项目的开发和维护。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值