makefile

makefile | makefile语法基础

2019-08-22  本文已影响0人  shawn233

makefile是为make指令提供信息的文件。make指令直接解析makefile。因此我们从make指令的起源谈起。

在开发大型项目时,上百个源文件的管理是个大问题,特别是应该按什么顺序编译这些文件。有人会说,这个问题好办啊,我写一个shell脚本按顺序执行所有的编译指令,让.s .o文件等按顺序生成,不就行了吗。这的确是一个解决的办法,但是呢,如果你真的把这个脚本用在大型项目上,会收到程序员们的投诉:我们用了这个脚本,每次改两行代码想看看效果就得编译半个小时,还不如我们从改动的文件开始手动编译呢。make工具就应程序员们的抱怨诞生了(情节纯属虚构,具体已不可考)。

make工具解决的问题正是大型项目源文件的管理问题。make的工作原理很好理解。之前我们提到把编译的指令按顺序保存在脚本里,就可以维护好源文件的编译顺序,但这样做带来的问题是重复编译。具体来说,重复编译就是指已经编译好的,没有被改动过的源文件又被重新编译了一次。make工具为了防止重复编译,采用的办法就是比较这些源文件和编译后的文件,看它们的版本是否一致,如果源文件(somefile.c)的版本比编译后的文件(somefile.o)新,就意味着需要重新进行编译。想要做这件事情,make文件需要知道两个信息:

依赖关系和指令是makefile里两个最重要的基础语法。之后我们会在这两个语法上发展变化。

下面是一个最基础的例子,其中的Makefile文件用上面提到的两种语法写成,就是我们这里说到的makefile。读者可以将所有的文件保存到同一个目录下,然后执行make,观察运行结果。(还没写)


Reference: 老李的地下室:Linux环境下make指令和makefile文件详解

上一篇下一篇

猜你喜欢

热点阅读