Makefile入门小试

在Linux上进行C/C++开发时我们通常使用GNU make工具来编译整个工程。接触过ARM Linux的朋友相信对于make和Makefile并不陌生。make只是一个工具,它在工作的时候需要一个名为Makefile的文件来告诉它如何去工作。

Makefile的核心规则非常简单,它描述了目标文件及其依赖的文件以及当依赖文件更新时应该被执行的命令:

目标: [依赖项1] [依赖项2] ...

[<键盘tab键>命令]

 或:

目标: [依赖项1] [依赖项2] ...;[<键盘tab键>命令]

注意:命令必须以tab键开头([]代表可选项)

 以编译hello.c的Makefile为例:

当执行make命令时,make会在当前目录下寻找Makefile文件。如果没有为make指定目标,一般将Makefile中的第一个目标作为最终目标。在上面这个Makefile中,第一个目标就是hello。hello拥有一个依赖文件(hello.o),当hello.o的修改日期比hello新时,会执行“gcc -o hello hello.o”命令来生成新的可执行文件hello。同样的,第5行的目标是hello.o,它依赖于hello.c这个文件。第5、6行指明了hello.o的依赖以及应该如何编译。整个流程是:如果我们修改了hello.c,hello.c的日期就会比hello.o新,此时make就会执行“gcc -c hello.c”来更新hello.o。这时候又因为hello.o比hello的日期新,因此make又会去执行第三行来更新hello

(执行make进行编译)

.PHONY表明clean是一个伪目标。clean并没有依赖的文件,当make执行它时它会将所有的.o文件以及编译生成的hello文件删除。整个工程中又只剩下.c文件及Makefile文件,非常清爽~~~~

(执行make clean清理工程)

通常而言一个工程中会存在很多.c文件,倘若像上面的Makefile中一样手动编写每一个.c文件的规则,这对于任何人来说都是一个噩梦!不过好在强大的make会自动推导命令和文件,这就是“隐含规则”

既然要使用隐含规则,那便不要再去编写具体的规则,让make自己去推导就好啦。在此之前,已经将printf("hello world!\r\n")放到了hello.c的hello()中,main.c通过调用hello()来输出“hello world!”。上文中我们编写了hello.o的规则,现在我们将其删掉,让make自己去推导:

(修改后的Makefile)

在新的Makefile中我们并没有定义.o文件的规则,但是在编译的过程中make确实为我们编译出了.o文件,同时最终生成的可执行文件main也确实打印出了“hello world!”:

(执行make)

从终端的输出中可以看到,make使用了隐含规则中的变量CC来调用默认的编译命令cc编译得到了main.o和hello.o,最后使用我们在Makefile中明确指定的规则来生成可执行文件main。那么问题来了,如果希望自己定义模式规则该怎么办呢??

我们可以通过编写模式规则来定义隐式规则:

Makefile的第7行指出.o文件依赖.c文件。例如,hello.o的依赖文件就是hello.c

自动变量表(部分)
%表示一个或多个任意字符。例如,%.c中的%代表的就是该.c文件的文件名
$()引用变量。例如,引用变量CC -> $(CC)
$@规则目标的文件名。例如:main.c、hello.c或main
$^所有依赖目标的集合
$<第一个依赖的名称

进一步将自己的Makefile进行整理,为了便于区分,这里将上文make生成的可执行文件的名称由main改成了run:

(修改后的Makefile)

 编译执行:

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Makefile是一种用来构建和管理程序的工具,它通过一个文本文件来指导编译器如何去编译、链接程序。理解并掌握Makefile的使用可以提高程序的编译效率和可维护性。下面是关于Makefile入门到精通的解释: 入门阶段: 在初学者阶段,需要掌握Makefile的基本语法和规则。学习如何编写一个简单的Makefile,并且能够使用Makefile来管理和编译一个简单的程序。掌握Makefile的目标、依赖关系、命令和变量的使用。 进阶阶段: 在进阶阶段,需要了解更多的Makefile的高级特性和技巧。学习如何使用条件语句、循环语句和函数来编写更灵活和复杂的Makefile。了解如何使用Makefile来管理多个源文件和目录结构。 精通阶段: 在精通阶段,需要深入理解Makefile背后的原理和机制。了解Makefile的工作原理,包括依赖关系的自动推导、文件更新的判断和并行编译等。还需要掌握一些高级的技巧,例如使用Makefile来实现代码自动生成、跨平台编译和项目的自动化构建等。 实践阶段: 在实践阶段,需要应用所学的知识来解决实际的编译和构建问题。学会分析和优化Makefile,以提高构建过程的效率和可维护性。实践中可能还需要了解如何与其他构建工具和版本控制系统进行集成,以及如何处理复杂的项目依赖关系。 总之,掌握Makefile需要从入门到精通经过一定的学习和实践过程。通过不断的学习和实践,逐渐提高对Makefile的理解和应用能力,才能真正驾驭Makefile并充分发挥其作用。 ### 回答2: Makefile是一种用于自动化编译和构建软件的脚本文件。它是基于依赖关系的构建工具,通过定义文件依赖关系和编译规则,可以自动检测源代码的变化并重新编译相关文件,从而提高软件开发的效率。 要学习Makefile,首先需要了解Makefile的基本语法和规则。Makefile由多个规则组成,每个规则包含目标文件、依赖文件和命令。目标文件是生成的文件,依赖文件是生成目标文件所需的源文件或其他目标文件,命令是生成目标文件的具体步骤。 在Makefile中,可以定义变量来存储常用的路径或编译选项,这样可以方便地在多个规则中复用。还可以使用条件判断、循环和函数等高级语法来实现更复杂的功能。 经常使用的命令有makemake clean和make install。make命令用于编译源代码并生成目标文件,如果源文件有更新,make会自动重新编译相关文件make clean命令用于清理生成的目标文件和临时文件make install命令用于安装生成的可执行文件或库文件到指定位置。 学习Makefile还需要掌握一些常用的编译规则和选项。例如,可以通过定义编译规则来指定编译器、编译选项和链接选项。可以使用特殊变量$@表示目标文件,$^表示所有的依赖文件,$<表示第一个依赖文件。还可以使用通配符和模式匹配来处理多个文件或目录。 除了基本的语法和规则,还可以学习一些高级的技巧和技术,例如使用配置文件、自动化测试、并行编译等。通过不断实践和积累经验,可以逐渐提高对Makefile的掌握程度,从入门到精通。 总结来说,要从入门到精通Makefile,需要掌握基本的语法和规则,学习常用的命令和选项,并通过实际项目的练习来加深理解和提高技能水平。 ### 回答3: makefile是一种用于自动化构建和管理项目的工具。它可以根据一组规则,自动推断出需要重新编译的文件,并且根据这些规则自动执行相应的指令,从而简化了项目的构建流程和维护工作。 首先,我们需要了解makefile的基本语法和组成部分。makefile由一系列规则组成,每个规则包含一个目标、依赖关系和执行的指令。目标是需要生成的文件,依赖关系是该文件生成所依赖的文件,指令则是实际执行的操作。 其次,学习makefile中的变量。变量可以用于存储常用的路径、命令等信息。使用变量可以简化项目配置和维护,提高可维护性。 然后,理解makefile中的模式规则。模式规则是一种通用的规则,可以根据目标和依赖的模式,推断出需要执行的指令。使用模式规则可以减少重复的规则定义,提高makefile的灵活性。 接下来,学习条件判断和循环控制。条件判断可以根据不同的情况选择执行不同的指令,循环控制可以重复执行某些指令。这些功能可以使makefile更加灵活和自动化。 最后,掌握makefile中的常用函数和命令。makefile提供了一系列内置函数和命令,用于处理文本、路径、文件等操作。熟练掌握这些函数和命令,可以提高makefile的处理能力和效率。 总结而言,要精通makefile需要掌握其基本语法、规则定义、变量使用、模式规则、条件判断、循环控制、内置函数和命令等知识。通过实践和不断学习,掌握这些内容后,就可以灵活运用makefile构建和管理项目,提高开发效率和代码质量。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值